



---

# Intel386™ Family

**Program Development Templates**



# PROGRAM DEVELOPMENT TEMPLATES

Order Number: 481894-001

| REV. | REVISION HISTORY | DATE  |
|------|------------------|-------|
| -001 | Original Issue.  | 01/89 |

In the United States, additional copies of this manual or other Intel literature may be obtained from:

Literature Department  
Intel Corporation  
3065 Bowers Avenue  
Santa Clara, CA 95051

In locations outside the United States, obtain additional copies of Intel documentation by contacting your local Intel sales office. For your convenience, international sales office addresses are printed on the last page of this document.

Intel Corporation makes no warranty of any kind with regard to this material, including, but not limited to, the implied warranties of merchantability and fitness for a particular purpose. Intel Corporation assumes no responsibility for any errors that may appear in this document. Intel Corporation makes no commitment to update nor to keep current the information contained in this document.

Intel Corporation assumes no responsibility for the use of any circuitry other than circuitry embodied in an Intel product. No other circuit patent licenses are implied.

Intel software products are copyrighted by and shall remain the property of Intel Corporation. Use, duplication or disclosure is subject to restrictions stated in Intel's Software License Agreement, or in the case of software delivered to the government, in accordance with the software license agreement as defined in FAR 52.227-7013.

No part of this document may be copied or reproduced in any form or by any means without prior written consent of Intel Corporation.

Intel Corporation retains the right to make changes to these specifications at any time, without notice.

Contact your local sales office to obtain the latest specifications before placing your order.

The following are trademarks of Intel Corporation and its affiliates and may be used only to identify Intel products. (Registered trademarks are followed by a superscripted ® .)

|               |                         |                 |                         |            |
|---------------|-------------------------|-----------------|-------------------------|------------|
| Above         | iLBX                    | Intellink       | MICROMAINFRAME          | Ripplemode |
| BITBUS        | im®                     | iOSP            | MULTIBUS®               | RMX/80     |
| COMMPuter     | iMDDX                   | iPAT            | MULTICHANNEL            | RUPI       |
| CREDIT        | iMMX                    | iPDS            | MULTIMODULE             | Seamless   |
| Data Pipeline | Inboard                 | iPSC            | ONCE                    | SLD        |
| ETOX          | Insite                  | iRMK            | OpenNET                 | SugarCube  |
| FASTPATH      | Intel®                  | iRMX®           | OTP                     | UPI        |
| Genius        | intel®                  | iSBC®           | PC BUBBLE               | VLSICE     |
| Δ             | Intel376                | iSBX            | Plug-A-Bubble           | 376        |
| i®            | Intel386                | iSDM            | PROMPT                  | 386        |
| i²ICE         | intcBOS                 | iSXM            | Promware                | 386SX      |
| ICE           | Intel Certified         | KEPROM          | QucX                    | 387        |
| iCEL          | Intlevision             | Library Manager | QUEST                   | 387SX      |
| iCS           | Intelligent Identifier  | MAPNET          | Quick-Erase             | 4-SITE     |
| iDBP          | Intelligent Programming | MCS®            | Quick-Pulse Programming |            |
| iDIS          | Intellic®               | Megachassis     |                         |            |

VAX and VMS are trademarks of Digital Equipment Corporation.

Copyright © 1989, Intel Corporation, All Rights Reserved

## Contents

---

### Chapter 1 Creating the Example Template Systems

|     |                              |   |
|-----|------------------------------|---|
| 1.1 | The Example Software.....    | 1 |
| 1.2 | Executing the Examples ..... | 3 |
| 1.3 | Related Publications.....    | 6 |
| 1.4 | Trademarks .....             | 6 |

### Chapter 2 Exploring the Templates

|       |                                                  |    |
|-------|--------------------------------------------------|----|
| 2.1   | Protected-Mode Programming .....                 | 1  |
| 2.1.1 | The Default Flat Memory Model .....              | 2  |
| 2.2   | The Embedded Example Templates.....              | 3  |
| 2.2.1 | The Initialization Template.....                 | 3  |
| 2.2.2 | The Build File Template .....                    | 8  |
| 2.2.3 | The Interrupt Stubs Template.....                | 12 |
| 2.2.4 | The C Startup Template.....                      | 14 |
| 2.2.5 | Creating the Embedded Example System .....       | 15 |
| 2.2.6 | The Embedded Example System .....                | 17 |
| 2.3   | The Protected Flat Memory Model.....             | 20 |
| 2.4   | The Protected Example Templates.....             | 22 |
| 2.4.1 | The Initialization Template.....                 | 22 |
| 2.4.2 | The Build File Template .....                    | 27 |
| 2.4.3 | The Interrupt Routine Template .....             | 29 |
| 2.4.4 | The Assembler Application Startup Template.....  | 30 |
| 2.4.5 | Creating the Protected Flat Example System ..... | 33 |
| 2.4.6 | The Protected Flat Example System.....           | 33 |

### Appendix

---

#### Glossary

---

#### Index

---

## Figures

---

|     |                                                          |      |
|-----|----------------------------------------------------------|------|
| 2-1 | Default Flat Memory Model.....                           | 2-2  |
| 2-2 | Embedded Example Source Code.....                        | 2-3  |
| 2-3 | Embedded Example System Memory Map .....                 | 2-17 |
| 2-4 | Minimally Protected Flat Memory Model .....              | 2-20 |
| 2-5 | Protected Flat Memory Model with Expand-down Stack ..... | 2-21 |
| 2-6 | Protected Example Source Code.....                       | 2-22 |
| 2-7 | Protected Example System Memory Map .....                | 2-34 |

## Tables

---

|                                                      |     |
|------------------------------------------------------|-----|
| Files for Simple Example .....                       | 1-2 |
| Files for Embedded Example with Interrupt Stubs..... | 1-2 |
| Files for Protected Example.....                     | 1-3 |
| Required Hardware and Software .....                 | 1-3 |
| Template File Names for V1.1 and V2.0.....           | A-1 |

# Chapter 1

## Creating the Example Template Systems

---

Creating a flat (linear) model bootloadable system for an Intel386™ family microprocessor is straightforward. BLD386, the system builder, assigns absolute addresses and makes the necessary system data structures. Several working examples are included on your diskette. You can build the example systems and monitor their execution on an in-circuit emulator without prior knowledge of the Intel386 architecture, and without knowing how the systems work; just follow the the step-by-step directions in Section 1.2.

Chapter 2 contains discussions of the templates and the flat memory models they represent. Certain Intel-specific terms used here may be unfamiliar to you, such as 32-bit protected mode, descriptor, segment, or gate. If you come across unfamiliar terms, or if you are interested in learning more about the Intel386 architecture, see the Glossary at the end of this booklet or the *Introduction to the 80386* or the *80386 Programmer's Reference Manual* listed at the end of this chapter.

### 1.1 The Example Software

The software files are templates because they are patterns you can build upon and modify in creating your own bootloadable system. There is code for three different C applications and an assembler application, each of which can be built into a bootloadable system. Three different kinds of systems can be built:

- a simple RAM system that runs without any interrupt handlers
- a typical embedded system with code in ROM and data and tables in RAM
- a system protected from stack overflow

The templates include all of the source code, some sample applications, the commands necessary to build the sample systems, and commands for an ICE-386™ or ICE-376™ in-circuit emulator to demonstrate the sample systems. The tables that follow group the files by the type of example system they build.

| FILES FOR SIMPLE EXAMPLE                           |                                                           |
|----------------------------------------------------|-----------------------------------------------------------|
| File name                                          | Description                                               |
| <b>simpinit.asm</b>                                | microprocessor initialization code                        |
| <b>cstart.asm</b>                                  | startup code for C application                            |
| <b>simple.c</b>                                    | simple C-386 application                                  |
| <b>simple.bld</b>                                  | BLD386 system definitions                                 |
| <b>simple.bat</b> {DOS}<br><b>simple.com</b> {VMS} | commands for assembling, compiling, binding, and building |
| <b>showsimp.inc</b>                                | simple system emulator commands                           |

| FILES FOR EMBEDDED EXAMPLE WITH INTERRUPT STUBS |                                                           |
|-------------------------------------------------|-----------------------------------------------------------|
| File name                                       | Description                                               |
| <b>flatinit.asm</b>                             | microprocessor initialization code                        |
| <b>flatintr.asm</b>                             | interrupt stubs                                           |
| <b>cstart.asm</b>                               | startup code for C application                            |
| <b>bitcount.c</b>                               | C-386 application                                         |
| <b>reverse.c</b>                                | C-386 application                                         |
| <b>flat.bld</b>                                 | BLD386 system definitions                                 |
| <b>flat.bat</b> {DOS}<br><b>flat.com</b> {VMS}  | commands for assembling, compiling, binding, and building |
| <b>showbitc.inc</b>                             | bitcount system emulator commands                         |
| <b>showrevr.inc</b>                             | reverse system emulator commands                          |

| FILES FOR PROTECTED EXAMPLE                          |                                                |
|------------------------------------------------------|------------------------------------------------|
| File name                                            | Description                                    |
| <b>protinit.asm</b>                                  | microprocessor initialization code             |
| <b>protintr.asm</b>                                  | interrupt procedure for asmstart               |
| <b>asmstart.asm</b>                                  | startup code for ASM386 application            |
| <b>protect.asm</b>                                   | ASM386 application                             |
| <b>protect.bld</b>                                   | BLD386 system definitions                      |
| <b>protect.bat</b> (DOS)<br><b>protect.com</b> (VMS) | commands for assembling, binding, and building |
| <b>showprot.inc</b>                                  | <b>protect</b> system emulator commands        |

## 1.2 Executing the Examples

You can execute the examples by following these simple directions.

- 1) Please ensure that your development system has the following software and hardware:

| REQUIRED HARDWARE AND SOFTWARE |         |                                                    |
|--------------------------------|---------|----------------------------------------------------|
| Name                           | Version | Description                                        |
| asm386                         | V3.0    | Macro Assembler                                    |
| c386                           | V1.0    | C-386 C Compiler                                   |
| bnd386                         | RLLv1.3 | Binder (V1.3)                                      |
| bld386                         | RLLv1.3 | System Builder (V1.4)                              |
| ice386<br>ice376               |         | ICE-386 or ICE-376 In-Circuit Emulator on DOS host |

- 2) Copy all the template files to your working directory. For VMS, the template files are located in the directory

**SYS&ROOT:[SYSHLP.EASE]**. For DOS, the files are located on the diskette entitled **Program Development Templates**. All files are ASCII text.

- 3) To create an example system, invoke the appropriate file of commands.

|     |                        |                                                  |
|-----|------------------------|--------------------------------------------------|
| DOS | simple system:         | <b>simple</b>                                    |
|     | embedded system:       | <b>flat bitcount</b> or<br><b>flat reverse</b>   |
|     | protected system:      | <b>protect</b>                                   |
| VMS | simple system:         | <b>@simple</b>                                   |
|     | embedded system:       | <b>@flat bitcount</b> or<br><b>@flat reverse</b> |
|     | protected flat system: | <b>@protect</b>                                  |

These commands assemble, compile (if necessary), bind, and build the system. The assembler and builder issue valid warning messages designed to guide careful creation of the systems. You can ignore these messages.

- 4) For VMS, download your system (**simple**, **bitcount**, **reverse**, or **protect**) and corresponding file of emulator commands (**showsimp.inc**, **showbitc.inc**, **showrevr.inc**, or **showprot.inc**) to your DOS in-circuit emulator host.
- 5) On your DOS in-circuit emulator host, change to your ICE-386 or ICE-376 in-circuit emulator software directory. Copy the system (**simple**, **bitcount**, **reverse**, or **protect**) from your working directory to your in-circuit emulator software directory. Then copy the corresponding file of emulator commands (**showsimp.inc**, **showbitc.inc**, **showrevr.inc**, or **showprot.inc**) from your working directory to your in-circuit emulator software directory.
- 6) Press the reset button on the in-circuit emulator. Invoke the in-circuit emulator.

**ice386 or**  
**ice376**

7) At the -> prompt, include the sequence of commands written for you by typing in one of the following followed by a carriage return.

```
->include nolist showsimp.inc /* for showing simple */
->include nolist showbitc.inc /* for showing bitcount */
->include nolist showrevr.inc /* for showing reverse */
->include nolist showprot.inc /* for showing protect */
```

8) To start the commands, at the -> prompt type the name of the system you have created followed by a carriage return.

|            |                        |
|------------|------------------------|
| ->simple   | /* to view simple */   |
| ->bitcount | /* to view bitcount */ |
| ->reverse  | /* to view reverse */  |
| ->protect  | /* to view protect */  |

9) Follow the execution of your system, entering a carriage return when prompted.

The ICE-386 in-circuit emulator issues error #-26t on the istrp command. Though the message is valid, you can ignore it because the emulator chip is executing in real mode and no selectors are accessible.

The sequence of emulator commands ends when the emulator returns you to the -> prompt. You can view another sample system that you have created by returning to step 7 of these directions, or you can exit the emulator. To exit the emulator, type **exit**.

**->exit**

## 1.3 Related Publications

The following publications contain further information on the Intel386 family of microprocessors.

*Intel386™ Family System Builder User's Guide*, order number 481342

*Intel386™ Family Utilities User's Guide*, order number 481343

*Introduction to the 80386*, order number 231252

*80386 Programmer's Reference Manual*, order number 230985

*80386 System Software Writer's Guide*, order number 231499

*ASM386 Assembly Language Reference Manual*, order number 480251

*ASM386 Macro Assembler Operating Instructions for DOS Systems*,  
order number 451290

*ASM386 Macro Assembler Operating Instructions for VAX/VMS Systems*, order number 167675

*C-386 User's Guide*, order number 481378

*ICE™-376 In-Circuit Emulator User's Guide*, order number 481753

*ICE™-386 In-Circuit Emulator User's Guide*, order number 481404

*ICE™-386/25 In-Circuit Emulator User's Guide*, order number 481749

*ICE™-386SX™ In-Circuit Emulator User's Guide*, order number 451989

## 1.4 Trademarks

Intel386, 376, 386, 386SX, and ICE are trademarks of Intel Corporation.

VAX and VMS are trademarks of Digital Equipment Corporation.

## Chapter 2

# Exploring the Templates

---

You can use the templates in many different systems. They are easy to understand and are at the heart of most embedded, 32-bit protected-mode systems.

Section 2.1 describes the flat model for 32-bit protected-mode programming. It explores the flat control for the system builder and the build file of system definitions. Section 2.2 describes the templates for the embedded examples with interrupt stubs. Most of this information applies to the other example systems as well. Section 2.3 describes adding protection to the flat model. Section 2.4 describes the protected example templates, including implementing a protected expand-down stack.

### 2.1 Protected-Mode Programming

Your code must initialize the Intel386™ family microprocessor to run in 32-bit protected mode after system reset. Each example system has code to initialize the microprocessor to run in protected mode. The key that simplifies the initialization is using the system builder, BLD386, which creates the absolute 32-bit protected-mode system from your code.

The builder builds an absolute 32-bit protected-mode system from the linked input segments you provide. You also provide a build file that defines system implementation details. This build file may contain information such as protection levels, system data structure definitions, and memory configuration. Each example system has a template build file.

The Intel386 family of microprocessors enables you to program in 32-bit protected mode using a flat memory model. The flat model is easy to use because all address space is linear. The flat model is good for systems that require large amounts of memory for data or code.

## 2.1.1 The Default Flat Memory Model

The feature of the system builder that makes the flat memory model easy to use is the **flat** control. Using the **flat** control, you can implement many details of a flat model system automatically. When **flat** is used, the builder:

- Creates two segments called **\_phantom\_code\_** and **\_phantom\_data\_**. The default descriptor privilege level (DPL) value is zero, or most privileged. These overlaid segments each have a default base address of zero and a default limit of 4 gigabytes - 1. Figure 2-1 depicts the default flat memory model used by the builder.
- Combines input segments into the appropriate phantom segment in the order of input. Even though the segments are overlaid, the builder does not overlap true code and data. When ROM areas and RAM areas are specified in the build file, the builder allocates space for segments according to their access attributes: ROM receives read-only segments (tables and task state segments) and executable segments (code), RAM receives read-write segments (data and stack).



Figure 2-1 Default Flat Memory Model

---

- Adjusts gates and all relative and absolute jumps to use the base of the `_phantom_code_` descriptor.
- Adjusts all data and stack accesses to use the base of the `_phantom_data_` descriptor.

## 2.2 The Embedded Example Templates

The embedded example templates demonstrate the code necessary for a typical embedded application with interrupt stub routines. The initialization, startup, and interrupt code is written in ASM386 assembly language. The sample application is written in C-386. Figure 2-2 illustrates the structure of the files that contain the source code. Note that the compilation of the C application produces a `data` segment and a `code32` segment. The binder combines segments with like names. See Figure 2-3 in Section 2.2.6 to see how the modules become a bootloadable system.



Figure 2-2 Embedded Example Source Code

### 2.2.1 The Initialization Template

The initialization code template, `flatinit.asm`, contains two distinct parts. The first part, the `init_code` segment, places the microprocessor into 32-bit protected mode. Since the code runs on both the 386™ microprocessor (which, at reset, is in 16-bit real mode)

and the 376™ microprocessor (which, at reset, is in 32-bit mode), the `init_code` segment is a 32-bit segment. For correct execution on a 386 microprocessor, operand prefixes before some instructions change the default operand size.

The other part of the initialization code, `copytables` in the `code32` segment, copies the necessary parts of the descriptor tables created by the builder from ROM to RAM. In this example, ROM is in high memory and RAM is in low memory. The RAM address of the descriptor tables are calculated by ANDing the corresponding ROM address with 0000ffffH. The code copies 5 global descriptor table (GDT) entries and the first 17 interrupt descriptor table (IDT) entries down into RAM. This example has only 16 interrupt routines, for interrupts 0 through 14 and 16.

### NOTE FOR ROM-BASED SYSTEMS

If you are implementing a ROM-based system like this example, then the process of copying the descriptor tables to RAM may be important. The microprocessor attempts to write to the GDT descriptor's ACCESS bit upon execution of an `lgdt` or `lgdtr` instruction (load the global descriptor table register, GDTR). The GDT is initially in ROM. Unless the GDTR is loaded with a RAM-based address, your hardware must return a READY upon a write to ROM.

If your hardware does indeed return a READY after a write to ROM, then the step of copying descriptor tables down to RAM in the `copytables` routine is unnecessary. Ensure that your initialization code also loads the interrupt descriptor table register (IDTR) and simply replace the far jump destination at the end of the `code32` segment with that of your startup code (`c_startup` in the example).

After the code copies the necessary parts of each table from ROM to RAM, the code adjusts the base and limit values in the GDT and IDT alias descriptors in the global descriptor table.

A listing of the `flatinit.asm` file follows.

flatinit.asm  
Initialization code for flat (linear) model example

Version 2.0

Copyright Intel Corp., 1988

This template is intended for your benefit in developing applications/  
systems using Intel386(TM) family microprocessors. Intel hereby grants  
you permission to modify and incorporate it as needed.

This is initialization code to put the 386(TM) processor or 376(TM)  
processor into flat mode. It should work with all applications,  
but this model makes certain assumptions. The memory model is a typical  
embedded application model: descriptor tables and code reside  
in ROM and data is in RAM. This example assumes that ROM begins at  
0ffff0000H; since descriptor tables may need to be RAM-based for  
protected-mode execution, the code copies the builder-created GDT and IDT  
down into RAM with the RAM address being <ROM\_address AND 0000ffff>. It  
assumes five GDT entries: NULL, a GDT alias, an IDT alias, code, and data.  
The builder creates the GDT alias and IDT alias and places them,  
by default, in GDT[1] and GDT[2]. After entering protected mode,  
this code jumps to an ASM386 startup routine for a C application. You  
can change this JMP address to that of your code, or make the label of  
your code C\_STARTUP.

```
NAME flatstart           ; name of object module

EXTRN c_startup:near    ; this is the label jumped to after init_code
                         ; and copytables

pe_flag      equ 1        ; for setting PE bit
gaTias_off   equ 8        ; offset of GDT alias in GDT
ialias_off   equ 10H       ; offset of IDT alias in GDT
data_selc    equ 20H       ; offset of phantom data in GDT (GDT[4])
gdt_Tim      equ 27H       ; assume that 5 entries are all that are needed in GDT
idt_lim      equ 87H       ; assume that 17 entries are all that are needed in IDT

CODEMACRO    opprefix    ; macro to change default operand size
db 66H

ENDM

init_code    SEGMENT ER PUBLIC

; GDT_DESC and IDT_DESC are public symbols referred to in the build file.
; The LOCATION definitions in the TABLE section of the build file point to
; these labels; the builder stores the base and limit for the named table
; at this location in memory.

PUBLIC        gdt_desc
PUBLIC        idt_desc

gdt_desc     dp ?
idt_desc     dp ?
```

```

; START is a label that points to the true beginning of our executable
; code. The BOOTSTRAP control causes the builder to place a short jump to
; the named label (in this case, START) at the component reset vector.

PUBLIC      start

; Since this code initializes either a 386 or 376 processor into protected
; mode, the first instructions at START test for component type.
; The 386 processor at reset is in real or compatibility mode: the PE bit is
; off and the D bit for CS is not set. Instructions execute in their 16-bit
; form. The 376 processor at reset has the PE bit on as well as the D bit,
; so instructions execute in their 32-bit form.

nop          ; NOPs are for initializing a 386
nop          ; processor
start:
    cld          ; clear direction flag
    smsw bx      ; check for processor (376 or 386) at reset
    test bl,1     ; use SMSW rather than MOV for speed
    jnz pestart

; Loading the GDTR at REALSTART or PESTART depends on user hardware
; returning a READY after a write to ROM.

realstart:
    opprefx      ; is a 386 processor and in 16-bit real mode
    mov eax,offset gdt_desc
    opprefx      ; use operand prefix to
    and eax,0ffffh ; get 32-bit address of GDT pointer
    lgdtw cs:[eax] ; use operand prefix to
                    ; make address relative to reset area
                    ; load 24 bits of base into GDTR

    mov ax,bx      ; copy machine status word
    or al,pe_flag  ; set PE bit
    lmsw ax        ; load machine status word
    jmp next       ; flush prefetch queue

pestart:
    mov eax,offset gdt_desc
    and eax,0ffffh
    lgdt cs:[eax] ; is a 376 processor in 32-bit protected mode
                    ; get 32-bit address of GDT pointer
                    ; make address relative to reset area
                    ; load 32 bits of base into GDTR

next:
    xor eax,eax    ; initialize data selectors
    mov al,data_selc ; GDT[4] is _phantom_data_
    mov ds,ax
    mov ss,ax
    mov es,ax
    mov fs,ax
    mov gs,ax
    test bl,1
    jnz pejump

```

```

; Use C_STARTUP as the destination of this next jump if your hardware does
; return a READY on a write to ROM, and skip the COPYTABLES routine.

    oprefix                ; use operand prefix for 386 processor jump
pejump:
    jmp far ptr copytables ; first far jump causes A31-A20 to drop low

init_code ENDS

;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;

code32 SEGMENT ER PUBLIC      ; BND386 combines this with other code32
; segments

copytables:

; Copy GDT and IDT from ROM to RAM. Assume the RAM address for the tables is
; the ROM address AND 0000ffffH. This code uses the second GDT entry,
; the GDT alias at GDT[1] = (base of GDT) + galias_off.

    mov eax,offset gdt_desc    ; get address of gdt_desc
    mov ebx,dword ptr [eax]+2  ; base of GDT is 2 bytes past gdt_desc

; Move the GDT descriptors from ROM to RAM.

    mov esi,ebx                ; source of move is present GDT base
    and ebx,0ffffH              ; calculate address of new GDT
    mov edi,ebx                ; destination of move is calculated address
    mov ecx,gdt_lim+1          ; count of move is 5 entries X 8 bytes each
    rep movsb                  ; move 5 descriptors from ROM to RAM

; Modify the GDT alias at GDT[1] to reflect the new base and limit of
; the RAM-based GDT. The GDT alias is a data segment descriptor
; (read/write) which allows future modification of the GDT.
; Reload the GDTR with the new base and limit values. We do this by
; changing the GDT alias to reflect the new base and limit, saving the
; changes, setting up the GDT alias to reload the GDTR, reloading, and then
; restoring the GDT alias. EBX holds the new base address of the GDT.

; change base in second dword of GDT alias
    and dword ptr [ebx]+galias_off+4,0fffff00H
; change limit in GDT alias
    mov word ptr [ebx]+galias_off,gdt_lim
; save part of GDT alias
    mov edx,dword ptr [ebx]+galias_off+2
; set up new base for loading GDTR
    mov dword ptr [ebx]+galias_off+2,ebx
; reload the GDTR
    lgdt pword ptr [ebx]+galias_off
; restore saved part of GDT alias
    mov dword ptr [ebx]+galias_off+2,edx

;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;

; IDT mov from ROM to RAM

    mov eax,offset idt_desc    ; get address of idt_desc
    mov edx,dword ptr [eax]+2  ; base of IDT is 2 bytes past idt_desc

```

```

; Move the IDT descriptors from ROM to RAM.

    mov esi,edx          ; source of move is present IDT base
    and edx,0ffffH       ; calculate address of new IDT
    mov edi,edx          ; destination of move is calculated address
    mov ecx,idt_limit+1 ; count of move is 17 entries X 8 bytes each
    rep movsb            ; move 17 descriptors from ROM to RAM

; Modify the IDT alias descriptor at GDT[2] to reflect the new base and limit
; values for the RAM-based IDT and load the IDTR.  EBX holds the address of
; the new GDT.  EDX holds the address of the new IDT.

        ; change base in second dword of IDT alias
    and dword ptr [ebx]+alias_off+4,0ffff00H
        ; change limit in IDT alias
    mov word ptr [ebx]+alias_off,idt_lim
        ; save part of IDT alias
    mov ecx,dword ptr [ebx]+alias_off+2
        ; set up new base for loading IDTR
    mov dword ptr [ebx]+alias_off+2,edx
        ; load the IDTR
    lldt dword ptr [ebx]+alias_off
        ; restore saved part of IDT alias
    mov dword ptr [ebx]+alias_off+2,ecx

    jmp c_startup         ; jump to startup code

code32 ENDS

END

```

## 2.2.2 The Build File Template

The **flat.bld** build file containing system definitions is both simple and generically useful. The following briefly explains the use of each definition.

|                              |                                                                                                                                                                                                                                                                                                                                  |
|------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>SEGMENT</b><br>definition | sets the descriptor privilege levels (DPLs) of all input segments to zero, or most privileged. The builder creates the overlaid <b>_phantom_code</b> and <b>_phantom_data</b> segments when the <b>flat</b> control is used; they are included here as a reminder, even though their default descriptor privilege level is zero. |
| <b>TABLE</b><br>definition   | (first occurrence) defines the global descriptor table (named <b>GDT</b> ).                                                                                                                                                                                                                                                      |

TABLE  
definition's  
LOCATION  
specification

places the absolute base address and limit (describing the GDT) into memory defined in the initialization code. The symbol `gdt_desc` is an uninitialized 6-byte area in the initialization module. The **LOCATION** feature is handy when you are relocating code often: since BLD386 always places the correct base and limit values in memory, you can change the location of either your initialization module (containing `gdt_desc`) or of your GDT and re-build without re-assembling any code.

TABLE  
definition's  
BASE  
specification

absolutely locates the GDT at the specified address in memory. In this example the GDT goes in ROM. Knowing the exact base address of this table is useful when debugging.

TASK  
definition

defines a task for the system. If the system data structures representing a task are in the bootloadable system, then the in-circuit emulator initializes the processor and makes ready to execute the task. A flat model system does not require a task, however. The demonstration emulator commands reset the emulator to execute the initialization code.

GATE  
definition

creates gate descriptors. The 386 and 376 microprocessors require that interrupt descriptor table entries be interrupt, task or trap gates. Instead of creating gate descriptors in assembly language, BLD386 creates them with the **GATE** definition. The **ENTRY** specification for each gate specifies the public label of the interrupt handlers.

TABLE  
definition

(second occurrence) defines the interrupt descriptor table (named `IDT`), sets the location to store the base and limit of the table to be `idt_desc` in `init_code`, and places the interrupt gates in the table.

MEMORY  
definition

describes the physical memory setup of the hardware, and defines the location of the software system.

**MEMORY**  
definition's  
**RESERVE**  
specification

specifies holes in the address space, or defines address ranges used in other ways (such as destinations of copied descriptor tables). BLD386 cannot place any code or data in this area of memory.

**MEMORY**  
definition's  
**RANGE**  
specification

determines which address ranges are RAM or ROM. When ROM and RAM areas are specified in the build file, the builder allocates space for segments according to their access attributes: ROM receives read-only segments (tables and task state segments) and executable segments (code); RAM receives read-write segments (data and stack).

**TABLE**  
definition

(last occurrence) tells the builder that the default local descriptor table (which we named LDT1) it creates should not be put in the bootloadable system. The contents of the table does appear in the builder listing, however.

A listing of the **flat.bld** build file follows.

```

-- flat.bld
-- Build file for input to BLD386 to create flat model example
--
-- ****
-- Version 2.0
-- Copyright Intel Corp., 1988
-- This template is intended for your benefit in developing applications/
-- systems using Intel386(TM) family microprocessors. Intel hereby
-- grants you permission to modify and incorporate it as needed.
-- ****
-- ****

flat; -- build program id

SEGMENT
*segments      (DPL = 0),
_phantom_code_ (DPL = 0),
_phantom_data_ (DPL = 0);           -- Give all user segments a DPL of 0.
-- These two segments are created by
-- the builder when the FLAT control is used.
-- Their default DPL is 0; they are
-- listed here for reference only.

TABLE
      -- create GDT
GDT
      (LOCATION = gdt_desc,
      BASE = 0ffff0100H
      ); -- end GDT

      -- GDT_DESC is a public symbol in
      -- the "flatstart" initialization module.
      -- In the buffer starting at GDT_DESC,
      -- BLD386 places the GDT base and
      -- GDT limit values. Buffer must be
      -- 6 bytes long. The base and limit
      -- values are placed in this buffer
      -- as two bytes of limit plus
      -- four bytes of base in the format
      -- required for use by LGDT instruction.

TASK
  main task
  {BASE = 0ffff0200H,
  DATA = data,
  CODE = main,
  STACKS = (stack),
  NO INTENABLED
  };

      -- Task is for ICE(TM)-386 or
      -- ICE(TM)-376 emulator initialization.

      -- Points to a segment that
      -- indicates initial DS value.
      -- Entry point is main, which
      -- must be a public id.
      -- Segment id points to stack
      -- segment. Sets the initial SS:ESP.
      -- Disable interrupts.

GATE
  int0_gate  (INTERRUPT, DPL = 0, ENTRY = int0),
  int1_gate  (INTERRUPT, DPL = 0, ENTRY = int1),
  int2_gate  (INTERRUPT, DPL = 0, ENTRY = int2),
  int3_gate  (INTERRUPT, DPL = 0, ENTRY = int3),
  int4_gate  (INTERRUPT, DPL = 0, ENTRY = int4),
  int5_gate  (INTERRUPT, DPL = 0, ENTRY = int5),
  int6_gate  (INTERRUPT, DPL = 0, ENTRY = int6),

```

```

int7_gate  {INTERRUPT, DPL = 0, ENTRY = int7},
int8_gate  {INTERRUPT, DPL = 0, ENTRY = int8},
int9_gate  {INTERRUPT, DPL = 0, ENTRY = int9},
int10_gate {INTERRUPT, DPL = 0, ENTRY = int10},
int11_gate {INTERRUPT, DPL = 0, ENTRY = int11},
int12_gate {INTERRUPT, DPL = 0, ENTRY = int12},
int13_gate {INTERRUPT, DPL = 0, ENTRY = int13},
int14_gate {INTERRUPT, DPL = 0, ENTRY = int14},
int16_gate {INTERRUPT, DPL = 0, ENTRY = int16};

```

TABLE

```

-- create IDT
IDT      (LOCATION = idt_desc,
           -- IDT_DESC is a public symbol in the
           -- "flatstart" initialization module.
           -- In the buffer starting at IDT_DESC
           -- the builder places two bytes of the IDT
           -- limit and four bytes of the IDT base
           -- values in the format required for use
           -- by LIDT instruction.

           BASE = 0ffff0000H,
           -- Slots 0 through 31 are Intel-reserved

           ENTRY = (0:int0_gate,   1:int1_gate,   2:int2_gate,   3:int3_gate,
                     4:int4_gate,   5:int5_gate,   6:int6_gate,   7:int7_gate,
                     8:int8_gate,   9:int9_gate,   10:int10_gate, 11:int11_gate,
                     12:int12_gate, 13:int13_gate, 14:int14_gate, 16:int16_gate)
); -- end IDT

```

MEMORY

```

(RESERVE = (0..250H),      -- For copying down IDT and GDT.
 RANGE = (                -- begin configuration section --
           rom_area = ROM(0ffff0000H..0fffff00H),
           ram_area = RAM(251H..0ffffH)
         )                  -- end configuration section --
);

```

TABLE

```

ldt1 (NOT CREATED);      -- Builder does not place LDT in object
                           -- module, but contents appear in listing.

```

END

## 2.2.3 The Interrupt Stubs Template

A listing of the interrupt stubs in the file **flatintr.asm** follows. Intel reserves the first 32 interrupts. Those which have been defined have a stub.

```

; flatintr.asm
; Interrupt fault handlers for use with flat model example
;
; ****
;
; Version 2.0
; Copyright Intel Corp., 1988
; This template is intended for your benefit in developing applications/
; systems using Intel386(TM) family microprocessors. Intel hereby
; grants you permission to modify and incorporate it as needed.
;
; ****

NAME interrupts
intrpt_routines SEGMENT ER PUBLIC

PUBLIC int0,int1,int2,int3,int4,int5,int6,int7,int8,int9,int10,int11
PUBLIC int12,int13,int14,int16

; If an exception occurs, the corresponding fault handler is
; entered. The interrupt number is pushed on top of the stack.

int0 : push 00H           ; divide error
       jmp entrez
int1 : push 01H           ; debug exceptions
       jmp entrez
int2 : push 02H           ; non-maskable interrupt
       jmp entrez
int3 : push 03H           ; breakpoint
       jmp entrez
int4 : push 04H           ; overflow
       jmp entrez
int5 : push 05H           ; bounds check
       jmp entrez
int6 : push 06H           ; invalid opcode
       jmp entrez
int7 : push 07H           ; coprocessor not available
       jmp entrez
int8 : push 08H           ; double fault
       jmp entrez
int9 : push 09H           ; coprocessor segment overrun
       jmp entrez
int10 : push 0AH          ; invalid tss
       jmp entrez
int11 : mov ax,ds
        mov ds,ax
        mov ax,es
        mov es,ax
        push 0BH
        jmp entrez
; segment not present
; ensure full loading of the segment registers
int12 : mov ax,ds
        mov ds,ax
        mov ax,es
        mov es,ax
        push 0CH
        jmp entrez
; stack exception
; ensure full loading of the segment registers
int13 : push 0DH           ; general protection

```

```

        jmp entrez
int14 : push 0EH          ; page fault
        jmp entrez
int16 : push 10H          ; coprocessor error
entrez : hlt
intrupt_routines ENDS
END

```

## 2.2.4 The C Startup Template

The code in `cstart.asm` defines a stack for a C application. The stack pointer is initialized, and the C routine is called. A listing of the `cstart.asm` file follows.

```

; cstart.asm
; An ASM386 module to initialize the stack and call a C application
; ****
; Version 2.0
; Copyright Intel Corp., 1988
; This template is intended for your benefit in developing applications/
; systems using Intel386(TM) family microprocessors. Intel hereby
; grants you permission to modify and incorporate it as needed.
; ****
; NAME cstart          ; name of the object module
; EXTRN main:near      ; label of the C application to be called
; PUBLIC c_startup      ; public symbol used in processor initialization code
stack STACKSEG 1024
data SEGMENT RW PUBLIC
data ENDS
code32 SEGMENT ER PUBLIC
c_startup:
    mov esp,stackstart stack ; initialize stack pointer
    call main                ; call C application
    hlt                     ; halt processor
code32 ENDS
END

```

## 2.2.5 Creating the Embedded Example System

Your template software includes a file of commands for assembling, compiling, binding, and building your 32-bit protected-mode system.

The three invocations of ASM386 create object modules **flatinit.obj**, **flatintr.obj** and **cstart.obj**. The assembler issues warnings with each invocation due to the use of privileged instructions in the files. The **debug** control directs ASM386 to include extra information useful in symbolic debugging. The listing files are **flatinit.lst**, **flatintr.lst**, and **cstart.lst**.

| VMS:                             | DOS:                             |
|----------------------------------|----------------------------------|
| <b>asm386/debug flatinit.asm</b> | <b>asm386 flatinit.asm debug</b> |
| <b>asm386/debug flatintr.asm</b> | <b>asm386 flatintr.asm debug</b> |
| <b>asm386/debug cstart.asm</b>   | <b>asm386 cstart.asm debug</b>   |

The invocation of C-386 creates an object module **parameter.obj**, where the **parameter** is replaced with the name of the application code file without its extension. The **regallocate** control directs the compiler to optimize the allocation of register variables. The **code** control causes placement of a pseudo-assembly language listing at the end of the listing file. **Debug** directs C-386 to include extra information useful in symbolic debugging. The listing file is **parameter.lst**.

| VMS:                                     | DOS:                                    |
|------------------------------------------|-----------------------------------------|
| <b>c386/debug/regallocate/code 'p1.c</b> | <b>c386 #1.c debug regallocate code</b> |

BND386 combines the input segments and resolves symbolic addressing. The **noload** control directs the binder to create a linkable (rather than loadable) file. The **debug** control indicates that the binder does not purge debug information. **Object** directs the output file to be named **parameter.bnd**. The listing file is **parameter.mpl**.

| VMS:                                                                    | DOS:                                                                    |
|-------------------------------------------------------------------------|-------------------------------------------------------------------------|
| <b>bnd386/noload/debug/object='p1.bnd 'p1.obj, flat.obj, cstart.obj</b> | <b>bnd386 #1.obj, flat.obj, cstart.obj noload debug object (#1.bnd)</b> |

The goal is an absolute bootloadable file (all addresses fixed in memory) suitable for loading into an ICE™-386 or ICE™-376 in-circuit

emulator. BLD386 creates such an absolute module, necessary descriptor tables, and a task for initializing the emulator. The **buildfile** control identifies **flat.bld** as the build file. The **bootstrap** control identifies the symbol **start** as the label of the instruction to be jumped to by the bootstrap jump placed at 0fffffff0H. The **flat** control directs the builder to configure the file in a flat model, where all code resides in the **\_phantom\_code** segment and all data resides in the **\_phantom\_data** segment. The **mod376** control causes the builder to issue messages to guide creation of the object module for a 376 processor. The warning about overlapping memory is such a guide. You can remove this control to create an object module for a 386 processor. The listing file is **parameter.mp2**. The final system is **parameter**.

VMS:

```
bl3d386/buildfile=flat.bld/bootstrap=start/flat/mod376 'p1.bnd,intrpt.obj
```

DOS:

```
bl3d386 *1.bnd,intrpt.obj buildfile (flat.bld) bootstrap (start) flat mod376
```

## 2.2.6 The Embedded Example System

Figure 2-3 shows what the memory looks like with the location of code, data, and system data structures after building the system with a small C application.



Figure 2-3 Embedded Example System Memory Map

The maps portion of the builder listing file, `bitcount.mp2`, for the `bitcount` example system follows.

SEGMENT MAP

TABLE PBIT DPL ACCESS USE BASE LIMIT SEGMENT NAME

GDT

|   |   |   |    |    |           |             |              |
|---|---|---|----|----|-----------|-------------|--------------|
| 1 | 1 | 0 | RW | 16 | FFFF0100H | 00000037H   | GDT:         |
| 2 | 1 | 0 | RW | 16 | FFFF0000H | 000000FFH   | IDT:         |
| 3 | 1 | 0 | EO | 32 | 00000000H | FFFFFFFFFFH | PHANTOM_CODE |
| 4 | 1 | 0 | RW | 32 | 00000000H | FFFFFFFFFFH | PHANTOM_DATA |

LDT.1 (LDT1)

|   |   |   |     |    |           |             |                               |
|---|---|---|-----|----|-----------|-------------|-------------------------------|
| 1 | 1 | 0 | RW  | 16 | FFFF0138H | 00000037H   | LDT1:                         |
| 2 | 1 | 0 | ER  | 32 | FFFF0270H | 000000EDH   | BITCOUNT.CODE32               |
| 3 | 1 | 0 | RWD | 32 | 00001260H | FFFFFFFFFFH | BITCOUNT.DATA                 |
| 4 | 1 | 0 | ER  | 32 | FFFF0170H | 0000005EH   | BITCOUNT.INIT_CODE            |
| 5 | 1 | 0 | RWD | 32 | 00002260H | FFFFFFFFFFH | BITCOUNT.STACK                |
| 6 | 1 | 0 | ER  | 32 | FFFF0360H | 00000051H   | INTERRUPTS.INTERRUPT_ROUTINES |

GATE TABLE

| GATE NAME  | TABLE   | PBIT | DPL | TYPE    | WC | SELECTOR | OFFSET    |
|------------|---------|------|-----|---------|----|----------|-----------|
| INT1_GATE  | IDT(1)  | 1    | 0   | 386INTR | 0  | GDT(3)   | FFFF0364H |
| INT2_GATE  | IDT(2)  | 1    | 0   | 386INTR | 0  | GDT(3)   | FFFF0368H |
| INT3_GATE  | IDT(3)  | 1    | 0   | 386INTR | 0  | GDT(3)   | FFFF036CH |
| INT4_GATE  | IDT(4)  | 1    | 0   | 386INTR | 0  | GDT(3)   | FFFF0370H |
| INT5_GATE  | IDT(5)  | 1    | 0   | 386INTR | 0  | GDT(3)   | FFFF0374H |
| INT6_GATE  | IDT(6)  | 1    | 0   | 386INTR | 0  | GDT(3)   | FFFF0378H |
| INT7_GATE  | IDT(7)  | 1    | 0   | 386INTR | 0  | GDT(3)   | FFFF037CH |
| INT8_GATE  | IDT(8)  | 1    | 0   | 386INTR | 0  | GDT(3)   | FFFF0380H |
| INT9_GATE  | IDT(9)  | 1    | 0   | 386INTR | 0  | GDT(3)   | FFFF0384H |
| INT10_GATE | IDT(10) | 1    | 0   | 386INTR | 0  | GDT(3)   | FFFF0388H |
| INT11_GATE | IDT(11) | 1    | 0   | 386INTR | 0  | GDT(3)   | FFFF038CH |
| INT12_GATE | IDT(12) | 1    | 0   | 386INTR | 0  | GDT(3)   | FFFF0398H |
| INT13_GATE | IDT(13) | 1    | 0   | 386INTR | 0  | GDT(3)   | FFFF03A4H |
| INT14_GATE | IDT(14) | 1    | 0   | 386INTR | 0  | GDT(3)   | FFFF03A8H |
| INT16_GATE | IDT(16) | 1    | 0   | 386INTR | 0  | GDT(3)   | FFFF03ACH |
| INT0_GATE  | IDT(0)  | 1    | 0   | 386INTR | 0  | GDT(3)   | FFFF0360H |

80386 SYSTEM BUILDER  
12/14/88 15:12:29 PAGE 5

TASK TABLE

MAIN\_TASK: TABLE = GDT(6) PBIT = 1 DPL = 0  
BASE = FFFF0200H  
LIMIT = 00000067H  
SS0:ESP0= GDT(4):00002260H  
SS1:ESP1= -----  
SS2:ESP2= -----  
SS:ESP = GDT(4):00002260H  
PDR = -----  
CS:EIP = GDT(3):FFFF02B0H  
DS = GDT(4)  
LDT = -----  
IOPRIV = 00H  
INTERRUPT NOT ENABLED  
DEBUG NOT ENABLED  
INITIAL

PROCESSING COMPLETED. 1 WARNING, 0 ERRORS

## 2.3 The Protected Flat Memory Model

You can easily create a system which combines the advantages of the flat memory model with the added value that the segmentation hardware can trap invalid data, code, and stack references. This variant of the flat memory model is called protected flat.

Remember that both the phantom\_code and phantom\_data segments must have the same base address. The default base address for these segments is 0. Use the **SEGMENT** definition in the build file to specify a different base address evenly divisible by 64K bytes.

The phantom segments do not have to span the entire address space, nor do they have to have the same limit. The default limit for these segments is 4 gigabytes - 1. Use the **SEGMENT** definition in the build file to specify different limits for one or both of the phantom segments. The minimum definition of a protected flat model system is one that has at least one of the phantom segments with a limit of less than 4 gigabytes - 1.

Figure 2-4 shows an example of a minimally protected flat memory model with phantom data's limit less than 4 gigabytes - 1. Reference to data outside of phantom data causes a general protection fault.



Figure 2-4 Minimally Protected Flat Memory Model

In the default flat model, the builder puts the stack with the data in `_phantom_data_`. Code and data are not protected from stack overflow. In the protected flat model, you can define a separate expand-down stack outside of `_phantom_data_`, adding the value of protecting the rest of the system from stack overflow. The expand-down stack has the same base address as the phantom segments. The builder sets its size to at least 4K bytes.

Use the build file **SEGMENT** definition to define the stack as **ED** (expand-down), and to define a limit less than 4 gigabytes - 1 but greater than 0 bytes. Do not specify a base address for the stack. Install the stack segment's descriptor in the GDT with the **TABLE** definition.

Figure 2-5 shows an example of a protected flat memory model with a separate expand-down stack. Although the phantom segments' limits are shown to be the same, they could be different as long as neither overlapped the expand-down stack. (Remember, memory wraps from high to low addresses on the Intel386 processors.)



**Figure 2-5 Protected Flat Memory Model with Expand-down Stack**

---

## 2.4 The Protected Example Templates

The protected example templates differ from the embedded example templates in several ways. The phantom segments are not based at physical zero. The protected example demonstrates the creation of a separate expand-down stack. The application is written in assembly language. An interrupt procedure handles a dummy interrupt. Figure 2-6 illustrates the structure of the files that contain the source code for the protected example. See Figure 2-7 in Section 2.4.6 to see how the modules become a protected flat bootloadable system.



Figure 2-6 Protected Example Source Code

### 2.4.1 The Initialization Template

The initialization code template, `protinit.asm`, performs the same functions for the protected system as the initialization code for the embedded system. The first part, the `init_code` segment, places the microprocessor into 32-bit protected mode. The second part, `copytables` in the `code32` segment, copies the necessary parts of the descriptor tables created by the builder from ROM to RAM.

The major differences in code arise from the non-zero base of the phantom segments. The RAM addresses of the descriptor tables are still calculated by ANDing the corresponding ROM address with `0000ffffH`. The `gdt_desc` and `idt_desc` still hold the absolute base

and limit values for the two tables. To copy a table and adjust its alias descriptor in the GDT, the code calculates the relative base for the table, which is the offset of the new table from the non-zero phantom base. (Remember, memory wraps from high to low addresses on the Intel386 processors.)

For simplicity, the code holds the values of the non-zero phantom base and the relative offset of absolute zero from this base. If the base of the phantom segments changes, the code must also change. (The code can be independent if it accesses the non-zero phantom base in one of the phantom segments' descriptors and calculates the relative offset of absolute zero instead.)

A listing of the **protinit.asm** file follows. Highlights point out the major added or changed code dealing with the non-zero base of the phantom segments.

```
; protinit.asm
; Initialization code for protected flat (linear) model example
*****
; Version 2.0
; Copyright Intel Corp., 1988
; This template is intended for your benefit in developing applications/
; systems using Intel386(TM) family microprocessors. Intel hereby grants
; you permission to modify and incorporate it as needed.
*****
; This is initialization code to put the 386(TM) processor or the 376(TM)
; processor into protected flat mode. It should work with all applications,
; but this model makes certain assumptions. The memory model is a typical
; embedded application model: descriptor tables and code reside in ROM
; and data is in RAM. This example assumes that ROM begins at 0fffff0000H;
; since descriptor tables may need to be RAM-based for protected-mode
; execution, the code copies the builder-created GDT and IDT down into RAM
; with the RAM address being <ROM address AND 0ffffH> relative to the base
; of phantom code and phantom data . It assumes six GDT entries: NULL,
; a GDT alias, an IDT alias, code, data, and a separate stack. After
; entering protected mode, this code jumps to an ASM386 startup routine.
; You can change this JMP address to that of your code, or make the label
; of your code SYSTART.
*****
; Note: Changing the base of the phantom segments in the build file
; requires a similar change for the variables PHANTOM BASE and
; PHANTOM ZERO. The base of the phantom segments must be evenly
; divisible by 64K bytes.
*****
```

```

NAME protstart          ; name of object module

EXTRN systart:far      ; this is the label jumped to after init_code
                        ; and copytables

pe_flag    equ 1          ; for setting PE bit
galias_off equ 8          ; offset of GDT alias in GDT
ialias_off equ 10H         ; offset of IDT alias in GDT
data_selc   equ 20H         ; offset of phantom data_ in GDT (GDT[4])
gdt_Tim    equ 2FH          ; assume that 6 entries are all that are needed in GDT
idt_lim    equ 10FH         ; assume that 34 entries are all that are needed in IDT
phantom_zero equ 100000H      ; offset of absolute 0 from base of phantom segs
phantom_base equ BffffB000H    ; base of phantom segments

CODEMACRO    opprefix      ; macro to change default operand size
db 66H

ENDM

init_code    SEGMENT ER PUBLIC

; GDT_DESC and IDT DESC are public symbols referred to in the build file.
; The LOCATION definitions in the TABLE section of the build file point to
; these labels; the builder stores the base and limit for the named table
; at this location in memory.

PUBLIC      gdt_desc
PUBLIC      idt_desc

gdt_desc    dp  ?
idt_desc    dp  ?

; START is a label that points to the true beginning of our executable
; code. The BOOTSTRAP control causes the builder to place a short jump
; to the named label (in this case, START) at the component reset vector.

PUBLIC      start

; Since this code initializes either a 386 or 376 processor into protected
; mode, the first instructions at START test for component type.
; The 386 processor at reset is in real or compatibility mode: the PE bit is
; off and the D bit for CS is not set. Instructions execute in their 16-bit
; form. The 376 processor at reset has the PE bit on as well as the D bit,
; so instructions execute in their 32-bit form.

nop          ; NOPs are for initializing a 386
nop          ; processor

start:
    cld          ; clear direction flag
    smsw bx      ; check for processor (376 or 386) at reset
    test bl,1      ; use SMSW rather than MOV for speed
    jnz pestart

; Loading the GDTR at REALSTART or PESTART depends on user hardware
; returning a READY after a write to ROM.

realstart:    ; is a 386 processor and in 16-bit real mode

```

```

opprefx
  mov eax,offset gdt_desc      ; use operand prefix to
  opprefx
  and eax,0ffffh               ; get 32-bit address of GDT pointer
  lgdtw cs:[eax]               ; use operand prefix to
                                ; make address relative to reset area
                                ; load 24 bits of base into GDTR

  mov ax,bx
  or al,pe_flag
  lmsw ax
  jmp next                     ; copy machine status word
                                ; set PE bit
                                ; load machine status word with PE bit set
                                ; flush prefetch queue

pestart:
  mov eax,offset gdt_desc      ; is a 376 processor and in 32-bit protected mode
  and eax,0ffffh               ; get 32-bit address of GDT pointer
  lgdt cs:[eax]               ; make address relative to reset area
                                ; load 32 bits of base into GDTR

next:
  xor eax,eax
  mov al,data_selc            ; initialize data selectors
  mov ds,ax
  mov ss,ax
  mov es,ax
  mov fs,ax
  mov gs,ax
  test bl,1
  jnz pejump                  ; GDT[4] is _phantom_data_

; Use SYSTART as the destination of this next jump if your hardware does
; return a READY on a write to ROM, and skip the COPYTABLES routine.

opprefx
pejump:
  jmp far ptr copytables      ; use operand prefix for 386 processor jump
                                ; first far jump causes A31-20 to drop low

init_code ENDS

::::::::::::::::::::::::::::::::::

code32 SEGMENT ER PUBLIC

copytables:
; Copy GDT and IDT from ROM to RAM. Assume the RAM address for the tables
; is the absolute ROM address AND 0000ffffH. This code uses the
; second GDT entry, the GDT alias at GDT[1] = (base of GDT) + galias_off.

  mov eax,offset gdt_desc      ; get address of gdt_desc
  mov ebx,dword ptr [eax]+2    ; base of GDT is 2 bytes past gdt_desc
                                ; note that ebx holds absolute base of GDT

; Move the GDT descriptors from ROM to RAM.

  mov esi,ebx
  xor esi,phantom_base
  and ebx,0ffffH_
  add ebx,phantom_zero
  mov edi,ebx
  mov ecx,gdt_lim+1            ; source of move is base of GDT relative to
                                ; phantom segments
                                ; displacement of GDT in ROM
                                ; calculate offset of new GDT
                                ; destination of move is calculated address
                                ; count of move is 6 entries X 8 bytes each

```

```

rep movsb           ; move 6 descriptors from ROM to RAM

; Modify the GDT alias at GDT[1] to reflect the new base and limit of the
; RAM-based GDT. The GDT alias is a data segment descriptor (read/write)
; which allows future modification of the GDT. Reload the GDTR with the
; new base and limit values. We do this by changing the GDT alias
; to reflect the new base and limit, saving the changes, setting up the GDT
; alias to reload the GDTR, reloading, and then restoring the GDT alias.
; EBX holds the new base address of the GDT (relative). Note that the GDT
; alias holds the absolute base of the GDT (not relative to the
; phantom segments' base).

; change base in second dword of GDT alias
and dword ptr [ebx]+galias_off+4,0ffff00H
; change limit in GDT alias
mov word ptr [ebx]+galias_off,gdt_lim
; save part of GDT alias
mov edx,dword ptr [ebx]+galias_off+2
; get old absolute base for GDT
mov ecx,dword ptr [eax]+2
; calculate new absolute base for GDT
and ecx,0ffffH
; set up new base for loading GDTR
mov dword ptr [ebx]+galias_off+2,ecx
; reload the GDTR
lgdt pword ptr [ebx]+galias_off
; restore saved part of GDT alias
mov dword ptr [ebx]+galias_off+2,edx

; IDT mov from ROM to RAM

mov eax,offset idt_desc ; get address of idt_desc
mov edx,dword ptr [eax]+2 ; base of IDT is 2 bytes past idt_desc
; note that edx holds absolute base of IDT

; Move the IDT descriptors from ROM to RAM.

mov esi,edx           ; source of move is base of IDT relative to
xor esi,phantom_base ; phantom segments
and edx,0ffffH         ; displacement of IDT in ROM
add edx,phantom_zero ; calculate offset of new IDT
mov edi,edx           ; destination of move is calculated address
mov ecx,idt_lim+1     ; count of move is 34 entries X 8 bytes each
rep movsb             ; move 34 descriptors from ROM to RAM

; Modify the IDT alias descriptor at GDT[2] to reflect the new base and limit
; values for the RAM-based IDT and load the IDTR. EAX holds the address of
; IDT_DESC. EBX holds the address of the new GDT (relative). Note that the
; IDT alias holds the absolute base of the IDT (not relative to the phantom
; segments' base).

; change base in second dword of IDT alias
and dword ptr [ebx]+ialias_off+4,0ffff00H
; change limit in IDT alias
mov word ptr [ebx]+ialias_off,idt_lim
; save part of IDT alias
mov edx,dword ptr [ebx]+ialias_off+2

```

```

        ; get old absolute base of IDT
mov ecx,dword ptr [eax]+2
        ; calculate new absolute base of IDT
and ecx,0ffffH
        ; set up base for loading IDTR
        ; load the IDTR
lidt dword ptr [ebx]+ialias_off
        ; restore saved part of IDT alias
        ; jump to startup code
mov dword ptr [ebx]+ialias_off+2,edx
jmp systart

code32 ENDS
END

```

## 2.4.2 The Build File Template

The **protect.bld** build file containing system definitions is where the work is done to define the protected flat memory model with an expand-down stack. The following explains the major changes.

|                              |                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>SEGMENT</b><br>definition | describes the segments. All of the segments get a descriptor privilege level of zero, or most privileged. One input segment becomes the separate expand-down stack. The phantom segments' base is set to a non-zero value evenly divisible by 64K bytes, and their limits are set to values less than 4 gigabytes - 1. The <u>phantom_code</u> segment's limit is less than the <u>phantom_data</u> segment's limit. |
| <b>TABLE</b><br>definition   | (first occurrence) defines the global descriptor table and explicitly places the expand-down stack descriptor in the sixth slot, GDT[5].                                                                                                                                                                                                                                                                             |
| <b>TABLE</b><br>definition   | (second occurrence) defines the interrupt descriptor table and explicitly places the interrupt gate in the 34th slot, IDT[33].                                                                                                                                                                                                                                                                                       |

A listing of the **protect.bld** build file follows. Highlights point out the major changes.

```

-- protect.bld
-- Build file for input to BLD386 to create protected flat model example
--
-- ****
--
-- Version 2.0
-- Copyright Intel Corp., 1988
-- This template is intended for your benefit in developing applications/
-- systems using Intel386(TM) family microprocessors. Intel hereby
-- grants you permission to modify and incorporate it as needed.
-- ****
-- ****
-- protflat; -- build program id

SEGMENT
  asmstart
    (DPL = 0),
    -- Give all user segments a DPL of 0.
    -- The name "asmstart" is the module-id
    -- for all segments because its object
    -- module is first in the BND386 input
    -- list.
    -- Protected stack is expand-down.
    -- A limit for the stack must be specified
    -- greater than 0 and less than 4 gigabytes,
    -- but the stack size is 4K bytes
    -- (or larger in 4K-byte steps).

  appstack
    (ED,
     LIMIT = 050H),
    -- The two _phantom_ segments are created
    -- by the builder when the FLAT control
    -- is used.
    -- Base values of both _phantom_ segments
    -- must be the same, and evenly divisible
    -- by 64K bytes.

    _phantom code
      (BASE = 0ffff0000H,
       LIMIT = 0ff00H),
    _phantom data
      (BASE = 0ffff0000H,
       LIMIT = 020000H);

TASK
  main task
    (BASE = 0ffff0300H,
     DATA = sysdata,
     CODE = systart,
     STACKS = (systack),
     NO INTENABLED
    );
    -- Task is for ICE(TM)-386 or
    -- ICE(TM)-376 emulator initialization.

    -- Points to a segment that
    -- indicates initial DS value.
    -- Entry point is systart, which
    -- must be a public id.
    -- Segment id points to stack
    -- segment. Sets the initial SS:ESP.
    -- Disable interrupts.

TABLE      -- create GDT
GDT
  (LOCATION = gdt_desc,
    -- GDT_DESC is a public symbol in
    -- the "protstart" initialization module.
    -- In a buffer starting at GDT_DESC,
    -- BLD386 places the GDT base and
    -- GDT limit values. Buffer must be
    -- 6 bytes long. The base and limit
    -- values are placed in this buffer

```

```

BASE = 0fffff0200H,
ENTRY = (5:appstack)
); -- end GDT

GATE
int_gate
(DPL = 0,
ENTRY = intproc,
INTERRUPT);

TABLE      -- create IDT
IDT        (LOCATION = idt_desc,
BASE = 0fffff0000H,
ENTRY = (33:int_gate)
); -- end IDT

MEMORY
(RESERVE = (0..300H),
RANGE = (
        -- begin configuration section --
        rom_area = ROM(0fffff0000H..0fffffff0H),
        ram_area = RAM(400H..0ffffH)
        ) -- end configuration section --
);

TABLE
1dt1 (NOT CREATED);

END

```

-- as two bytes of limit plus  
-- four bytes of base in the format  
-- required for use by LGDT instruction.

-- Explicitly install separate expand-down  
-- stack in GDT[5].

-- Define an interrupt gate for the  
-- interrupt handler.

-- IDT\_DESC is a public symbol in the  
-- "protstart" initialization module.  
-- In the buffer starting at IDT DESC  
-- the builder places two bytes of the  
-- IDT limit and four bytes of the IDT  
-- base values in the format required  
-- for use by LIDT instruction.  
-- Slots 0 through 31 are Intel-reserved.

-- For copying down IDT and GDT.

-- Builder does not place LDT in object  
-- module, but contents appear in listing.

## 2.4.3 The Interrupt Routine Template

One interrupt procedure is defined for a non-reserved interrupt. A listing of the **protintr.asm** file follows.

```
; protintr.asm
; ASM386 interrupt stub
; ****
;
; Version 2.0
; Copyright Intel Corp., 1988
; This template is intended for your benefit in developing applications/
; systems using Intel386(TM) family microprocessors. Intel hereby
; grants you permission to modify and incorporate it as needed.
; ****
;
; NAME int_proc
;
PUBLIC intproc
;
intcode SEGMENT EO PUBLIC
;
intproc PROC FAR
;
int33:
    hlt
    iretd
;
intproc ENDP
;
intcode ENDS
;
END
```

#### 2.4.4 The Assembler Application Startup Template

The code in the startup template for an assembler application defines a system stack, initializes the stack pointer, calls the application, and generates an interrupt. A listing of the `asmstart.asm` file follows.

```

; asmstart.asm
; ASM386 system startup code for protected flat model example
; ****
;
; Version 2.0
; Copyright Intel Corp., 1988
; This template is intended for your benefit in developing applications/
; systems using Intel386(TM) family microprocessors. Intel hereby
; grants you permission to modify and incorporate it as needed.
; ****
;
NAME    asmstart
PUBLIC  systart
EXTRN  app_entry:FAR
systack STACKSEG 100
sysdata SEGMENT RW
var2    dd 5
sysdata ENDS
syscode SEGMENT EO PUBLIC
ASSUME DS:sysdata, SS:systack
systart:
    inc esi           ; used as marker for tracing execution
    mov esp, stackstart systack ; initialize esp
    call app_entry    ; go to applic code
    inc esi           ; marker
    int 33            ; cause an interrupt
    inc esi           ; marker
systack ENDS
END systart, DS:sysdata, SS:systack

```

A listing of the **protect.asm** application follows.

```

; protect.asm
; ASM386 application code to demonstrate protected flat model
; ****
; Version 2.0
; Copyright Intel Corp., 1988
; This template is intended for your benefit in developing applications/
; systems using Intel386(TM) family microprocessors. Intel hereby
; grants you permission to modify and incorporate it as needed.
; ****

NAME    applic_func

PUBLIC  app_entry, error_entry, var1

appstack STACKSEG 40           ; This is the expand-down stack

applic_data SEGMENT RW PUBLIC
var1    dd ?
applic_data ENDS

ASSUME  DS:applic_data, SS:appstack

applic_code SEGMENT ER PUBLIC

const   dd 5

app_entry:
    mov ebp,esp
    mov ax,appstack           ; get selector for appstack
    mov ss,ax                 ; set SS selector
    mov esp,stackstart appstack ; get initial ESP value
    mov ebx,offset const      ; get CS relative offset
    mov eax,[ebx]              ; see if we get the constant from code
    push eax                 ; test stack access
    push eax                 ; test stack access
    pop var1                 ; test store
    sub esp,4088              ; reduce ESP for lesser loops

stack_loop:
    push eax                 ; loop until stack limit exception
    cmp eax,esp              ; insert your own limit comparison
    jne error_entry
    inc eax
    jmp stack_loop

; This does nothing except prove that the system works.

error_entry:
    mov ax,ds                ; restore SS with system stack selector
    mov ss,ax
    mov esp,ebp              ; restore ESP
    ret                      ; go back and cause interrupt

applic_code ENDS
END

```

## 2.4.5 Creating the Protected Flat Example System

You create the protected example system with essentially the same commands as the embedded example system. The binder links the interrupt module with the other modules to resolve symbolic addressing. The commands for assembling, binding, and building follow.

VMS:

```
asm386/debug protinit.asm
asm386/debug protect.asm
asm386/debug asmstart.asm
asm386/debug protintr.asm
```

DOS:

```
asm386 protinit.asm debug
asm386 protect.asm debug
asm386 asmstart.asm debug
asm386 protintr.asm debug
```

VMS:

```
bnd386/noload/debug/object=protect.bnd asmstart.obj, protect.obj,
protinit.obj, protintr.obj
```

DOS:

```
bnd386 asmstart.obj,protect.obj,protinit.obj,protintr.obj noload debug
object (protect.bnd)
```

VMS:

```
b1d386/buildfile=protect.bld/bootstrap=start/flat/mod376 protect.bnd
```

DOS:

```
b1d386 protect.bnd buildfile(protect.bld) bootstrap(start) flat mod376
```

## 2.4.6 The Protected Flat Example System

Figure 2-7 shows what the memory looks like with the location of code, data, and system data structures after building the protected example system.



Figure 2-7 Protected Example System Memory Map

The maps portion of the builder listing file for the **protect** example system follows.

80386 SYSTEM BUILDER  
12/14/88 13:33:02 PAGE 4

SEGMENT MAP

| TABLE               | PBIT | DPL | ACCESS | USE | BASE      | LIMIT      | SEGMENT NAME         |
|---------------------|------|-----|--------|-----|-----------|------------|----------------------|
| <b>GDT</b>          |      |     |        |     |           |            |                      |
| 1                   | 1    | 0   | RW     | 16  | FFFF0200H | 0000003FH  | GDT:                 |
| 2                   | 1    | 0   | RW     | 16  | FFFF0000H | 0000010FH  | IDT:                 |
| 3                   | 1    | 0   | EO     | 32  | FFFF0000H | 0000FF00H  | PHANTOM_CODE         |
| 4                   | 1    | 0   | RW     | 32  | FFFF0000H | 00020000H  | PHANTOM_DATA         |
| 5                   | 1    | 0   | RWD    | 32  | FFFF0000H | FFFFFEFFFH | ASMSTART.APPSTACK    |
| <b>LDT.1 (LDT1)</b> |      |     |        |     |           |            |                      |
| 1                   | 1    | 0   | RW     | 16  | FFFF0110H | 0000004FH  | LDT1:                |
| 2                   | 1    | 0   | EO     | 32  | FFFF0160H | 00000010H  | ASMSTART.SYSCODE     |
| 3                   | 1    | 0   | RW     | 32  | 00000400H | 00000006H  | ASMSTART.SYSDATA     |
| 4                   | 1    | 0   | RWD    | 32  | 00001408H | FFFFFEFFFH | ASMSTART.SYSTACK     |
| 5                   | 1    | 0   | ER     | 32  | FFFF0174H | 00000037H  | ASMSTART.APPLIC_CODE |
| 6                   | 1    | 0   | RW     | 32  | 00001408H | 00000006H  | ASMSTART.APPLIC_DATA |
| 7                   | 1    | 0   | ER     | 32  | FFFF0240H | 00000099H  | ASMSTART.CODE32      |
| 8                   | 1    | 0   | ER     | 32  | FFFF0368H | 0000005EH  | ASMSTART.INIT_CODE   |
| 9                   | 1    | 0   | EO     | 32  | FFFF01ACh | 00000001H  | ASMSTART.INTCODE     |

80386 SYSTEM BUILDER  
12/14/88 13:33:02 PAGE 5

GATE TABLE

| GATE NAME | TABLE   | PBIT | DPL | TYPE    | WC | SELECTOR | OFFSET    |
|-----------|---------|------|-----|---------|----|----------|-----------|
| INT_GATE  | IDT(33) | 1    | 0   | 386INTR | 0  | GDT(3)   | 000001ACh |

80386 SYSTEM BUILDER  
12/14/88 13:33:02 PAGE 6

TASK TABLE

MAIN\_TASK: TABLE = GDT(7) PBIT = 1 DPL = 0  
BASE = FFFF0300H  
LIMIT = 00000067H  
SS0:ESP0= GDT(4):00001408H  
SS1:ESP1= -----  
SS2:ESP2= -----  
SS:ESP = GDT(4):00001408H  
PDR = -----  
CS:EIP = GDT(3):00000160H  
DS = GDT(4)  
LDT = -----  
IOPRIV = 00H  
INTERRUPT NOT ENABLED  
DEBUG NOT ENABLED  
INITIAL

PROCESSING COMPLETED. 2 WARNINGS, 0 ERRORS

## Appendix

| TEMPLATE FILE NAMES FOR V1.1 AND V2.0  |                                          |
|----------------------------------------|------------------------------------------|
| V2.0 File name                         | V1.1 File name(s)                        |
| flatinit.asm                           | flat.a38                                 |
| simpinit.asm                           | flatsim.a38                              |
| protinit.asm                           | protflat.asm {DOS}<br>protflat.a38 {VMS} |
| flatintr.asm                           | intrpt.a38                               |
| protintr.asm                           | intproc.asm                              |
| cstart.asm                             | cstart.a38                               |
| asmstart.asm                           | sys.asm                                  |
| bitcount.c                             | bitcnt.c                                 |
| reverse.c                              | revrs.c                                  |
| simple.c                               | simple.c                                 |
| protect.asm                            | applic.asm                               |
| flat.bld                               | flat.bld                                 |
| simple.bld                             | simple.bld                               |
| protect.bld                            | applic.bld                               |
| flat.bat {DOS}<br>flat.com {VMS}       | flat.bat {DOS}<br>flat.com {VMS}         |
| simple.bat {DOS}<br>simple.com {VMS}   | flatsim.bat {DOS}<br>flatsim.com {VMS}   |
| protect.bat {DOS}<br>protect.com {VMS} | prot.bat {DOS}<br>prot.com {VMS}         |
| showbitc.inc                           | showbitc.inc                             |

| TEMPLATE FILE NAMES FOR V1.1 AND V2.0<br>(continued) |                      |
|------------------------------------------------------|----------------------|
| V2.0 File name                                       | V1.1 File name(s)    |
| showrevr.inc                                         | showrevr.inc         |
| showsimp.inc                                         | simple.inc           |
| showprot.inc                                         | sys.inc and sys1.inc |

## Glossary

---

Italicized words and phrases in a definition refer to other glossary entries.

**16-bit real mode**

the mode of execution on the 386™ microprocessor where the processor executes instructions in their 16-bit form. The *protection-enable (PE) bit* is off in the *machine status word*. Address calculation mimics the 8086 processor. The 386 microprocessor executes in this mode on reset.

**32-bit protected mode**

the mode of execution on the Intel386™ family microprocessors where the processor executes instructions in their 32-bit form. The *protection-enable (PE) bit* is on in the *machine status word*. The first *far jump* has been executed. This mode uses *selectors* and *descriptors* to calculate addresses. The 376™ microprocessor executes only in this mode. See also *protection*.

**32-bit segment**

a *segment* whose *use-attribute* is *USE32*. This attribute is the default for a segment. The *use-attribute* is represented by bit 54 (B/D) in a segment's *descriptor*. By default, addresses and operands are 32 bits long. A 32-bit segment naturally corresponds to executing in *32-bit protected mode*, but *operand prefixes* preceding some instructions allow the processor to execute a 32-bit segment in *16-bit real mode*. See also *D bit*.

**absolute addresses**

fixed locations in memory for data and code (contrary to relocatable addresses, which could change from execution to execution). See also *bootloadable system*, *physical address*, and *relocating*.

**access attributes**

characteristics which define the type of a *segment*: read-only data, read-write data, execute-read code, or execute-only code. These attributes are represented by bits 41 (W/R) and 43 (Executable) in a segment's *descriptor*.

|                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ACCESS bit                 | bit 24 in a segment's <i>descriptor</i> that is set when the segment <i>selector</i> has been loaded into a <i>segment register</i> or used by selector test instructions. The ACCESS bit in the <i>global descriptor table's alias descriptor</i> is set on execution of a load <i>global descriptor table register</i> (LGDT) instruction.                                                                                                       |
| alias,<br>alias descriptor | a segment <i>descriptor</i> which has <i>access attributes</i> contrary to the normal use of the <i>segment</i> . The <i>system builder</i> always creates a <i>global descriptor table</i> with an alias descriptor for the global descriptor table itself in GDT[1] and an alias descriptor for the <i>interrupt descriptor table</i> in GDT[2]. These aliases have access attributes that describe the <i>tables</i> as writable data segments. |
| base,<br>base address      | the lowest <i>offset</i> of the item being discussed (except <i>expand-down</i> segments). Typical items are <i>segments</i> , <i>tables</i> , and <i>task state segments</i> . In a flat memory model, if the phantom segments have a base address of zero, all base addresses are the same as their <i>physical addresses</i> . See also <i>relative base</i> and <i>expand-down</i> .                                                           |
| binder,<br>BND386          | the RLL (DOS) or R&L (VMS) utility that performs linking. The binder combines <i>segments</i> with like names and resolves symbolic addressing. The binder can produce a loadable <i>module</i> (relocatable) or linkable <i>module</i> (suitable for input to the binder or the <i>system builder</i> ). The binder cannot produce a <i>bootloadable system</i> .                                                                                 |
| bootloadable<br>system     | an object <i>module</i> with <i>absolute addresses</i> . A simple bootstrap loader can load a bootloadable system onto a target processor. The system contains code which initializes the processor on reset. See also <i>system builder</i> .                                                                                                                                                                                                     |
| bootstrap<br>jump          | the instruction located at the <i>reset vector</i> . Usually this instruction is a <i>near jump</i> to the initialization code.                                                                                                                                                                                                                                                                                                                    |

Italicized words and phrases in a definition refer to other glossary entries.

|                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|----------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| builder,<br>BLD386               | See <i>system builder</i> .                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| build file                       | a file of system implementation definitions used by the <i>system builder</i> to create a <i>bootloadable system</i> . The definitions describe <i>system data structures</i> , initial values for the system, and <i>memory configuration</i> .                                                                                                                                                                                                                                           |
| compatibility mode               | See <i>16-bit real mode</i> .                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| component                        | microprocessor.                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| D bit                            | bit 54 (B/D) in a segment's <i>descriptor</i> . The D bit refers to the default operand size of a code <i>segment</i> . If the bit is 1, the default operand size is 32 bits. If the bit is 0, the default operand size is 16 bits. See also <i>32-bit segment</i> .                                                                                                                                                                                                                       |
| descriptor                       | (1) eight bytes of memory containing the <i>base</i> , <i>limit</i> , and <i>access attributes</i> for a given region of linear address space such as a <i>segment</i> , <i>table</i> , or <i>task state segment</i> . Usually "descriptor" alone refers to the descriptor for a code or data segment. "Alias descriptor" most often refers to the descriptor for a table. "Task descriptor" or "TSS descriptor" refers to the descriptor for a task state segment.<br>(2) a <i>gate</i> . |
| descriptor privilege level (DPL) | bits 29 and 30 in a segment's <i>descriptor</i> . The <i>segmentation hardware</i> checks descriptor privilege levels on accesses to code and data <i>segments</i> to ensure that the referring code has sufficient privilege. A flat model system has all segments at privilege level 0, which obviates the privilege-level checking. See also <i>privilege levels</i> , <i>privileged instructions</i> , and <i>protection</i> .                                                         |

|                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| direction flag | bit 10 in the EFLAGS register. The value of this bit defines whether ESI and/or EDI registers postdecrement or postincrement during string instructions.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| entry point    | the first instruction to be executed in a code segment or task.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| expand-down    | a special kind of data segment useful for stacks. Stack growth is down from the <i>base address</i> . The expand-down attribute is in bit 42 of the segment's <i>descriptor</i> . A software system can dynamically increase the expand-down segment's size by lowering the <i>limit</i> in the segment's descriptor. A 32-bit expand-down segment's base address is one byte higher than its highest available address. Its lowest available address is the sum of its base plus limit plus one, ignoring any carry past 32 bits of address. Its size is the complement of its limit, or the difference of its base and lowest available address. Its minimum size is 4K bytes. |
| far jump       | an intersegment jump; this direct control-transfer instruction has a <i>selector</i> and <i>offset</i> representing the destination, which allows control to transfer to (possibly) a different code segment.                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| fault handler  | code which executes when a fault, or interrupt, is raised.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| gate           | eight bytes of memory used to regulate transfer of control to another code segment. A gate is sometimes called a <i>descriptor</i> because it has a layout similar to a segment descriptor. It contains information about the <i>selector</i> for the target segment, the <i>offset</i> of the <i>entry point</i> within the target segment, the type and <i>privilege level</i> of the gate, and the number of words to pass on the stack. Gates provide indirection that allows the processor to perform <i>protection</i> checks. Gate types can be call, interrupt, trap, or task.                                                                                           |

Italicized words and phrases in a definition refer to other glossary entries.

general protection fault

interrupt number 13 raised on a *protection* violation such as exceeding a segment *limit*, violating the *access attributes* of a *segment*, or violating *privilege levels*.

global descriptor table (GDT)

an array of *descriptors* defining *segments* and *gates* available for use by all *tasks* in the system. There is only one global descriptor table for a software system.

global descriptor table register (GDTR)

the system register that contains the *base* and *limit* of the *global descriptor table*.

interrupt descriptor table (IDT)

an array of *task*, interrupt, and/or trap *gates* that act as interrupt vectors; each gate's *slot* number is the interrupt number. There is only one interrupt descriptor table for a software system.

interrupt descriptor table register (IDTR)

the system register that contains the *base* and *limit* of the *interrupt descriptor table*.

interrupt stubs

*routines* that execute when an interrupt occurs but do essentially nothing.

limit

the *offset* of the farthest available byte from the *base address* in a *segment* that is not *expand-down*. This value is one less than the number of bytes in the segment. For a 32-bit expand-down segment, the limit is the complement of the number of bytes in the segment.

linear addresses

the same as *physical addresses* in a memory model which does not use any virtual memory.

linker

See *binder*.

|                                        |                                                                                                                                                                                                                                                                                                                                                                                                                               |
|----------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| local descriptor table (LDT)           | an array of <i>descriptors</i> defining <i>segments</i> and <i>gates</i> protected from use by all but specified <i>tasks</i> in the system. Tasks that have a pointer to a local descriptor table in their <i>task state segment</i> can access that table. Sometimes the <i>global descriptor table</i> also holds descriptors for local descriptor tables. There can be many local descriptor tables in a software system. |
| local descriptor table register (LDTR) | the system register that contains the <i>selector</i> for the <i>descriptor</i> of the currently active <i>local descriptor table</i> .                                                                                                                                                                                                                                                                                       |
| machine status word                    | bits 0 through 15 of control register 0 (CR0); contains the <i>protection-enable (PE) bit</i> .                                                                                                                                                                                                                                                                                                                               |
| module                                 | (1) a file of code in some stage of translation. An object module refers to the output of an assembler, compiler, <i>binder</i> , or <i>system builder</i> . An input module refers to a file in the form accepted by translating, linking, or building software. (2) a unit of code with some purpose, not necessarily an entire file, and possibly spanning several files.                                                  |
| near jump                              | an intrasegment jump; a direct control-transfer instruction with an <i>offset</i> representing the destination, thus allowing control to transfer to code within the same code <i>segment</i> .                                                                                                                                                                                                                               |
| offset                                 | the displacement; the number of units (usually bytes) away from the zeroth location in memory, or the number of units away from the <i>base address</i> of the enclosing <i>segment</i> or data structure.                                                                                                                                                                                                                    |
| operand prefix                         | a byte of memory with value 66H preceding an instruction. The processor uses an operand size other than the default when executing this instruction.                                                                                                                                                                                                                                                                          |
| overlaid segments                      | <i>segments</i> whose <i>base</i> and <i>limit</i> values cause them to share some or all of their <i>physical addresses</i> .                                                                                                                                                                                                                                                                                                |

Italicized words and phrases in a definition refer to other glossary entries.

|                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| physical address           | the <i>offset</i> of the first byte of an item from the zeroth byte in memory. The minimum physical address on the Intel386 microprocessors is zero; the maximum physical address is 4 gigabytes - 1, or ffffffffH. See also <i>absolute addresses</i> .                                                                                                                                                                                                                                               |
| prefetch queue             | the instruction pipeline on the Intel386 microprocessors.                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| privilege level            | one of four values: 0 (most privileged), 1, 2, or 3 (least privileged). The <i>descriptor privilege level (DPL)</i> of the currently executing code segment is also called the current privilege level (CPL). See also <i>selector</i> .                                                                                                                                                                                                                                                               |
| privileged instructions    | instructions that affect system registers or halt the processor. These instructions can only be executed when the current <i>privilege level</i> is 0.                                                                                                                                                                                                                                                                                                                                                 |
| protection                 | the mechanisms implemented by the hardware of the Intel386 microprocessors, especially when the <i>protection-enable (PE) bit</i> is on and the first <i>far jump</i> has been executed. There are five basic kinds of protection available: type checking, limit checking, restriction of addressable domain, restriction of <i>entry points</i> , and restriction of instruction set. See also <i>general protection fault</i> , <i>privileged instructions</i> , and <i>segmentation hardware</i> . |
| protection-enable (PE) bit | bit 0 in the <i>machine status word</i> . If PE is 1, the processor executes in <i>32-bit protected mode</i> . If PE is 0, the processor operates in <i>16-bit real mode</i> .                                                                                                                                                                                                                                                                                                                         |
| protection level           | See <i>descriptor privilege level (DPL)</i> , and <i>privilege level</i> .                                                                                                                                                                                                                                                                                                                                                                                                                             |
| real mode                  | See <i>16-bit real mode</i> .                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

|                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| relative base,<br>relative offset | the <i>offset</i> of the lowest address of the item being discussed from some other known address. An item such as a <i>table</i> that is located within a larger <i>segment</i> has a <i>base address</i> relative to the base address of the larger segment. If the larger segment has a physical base address of zero, the table's base and relative base are the same <i>physical address</i> .                                                                          |
| relocating                        | the process of changing the <i>physical address</i> of an item, and adjusting all references to that item.                                                                                                                                                                                                                                                                                                                                                                   |
| reset vector                      | <i>physical address</i> ffffff0H on the Intel386 family processors. The processor executes the instruction at this location first on reset. See also <i>bootstrap jump</i> .                                                                                                                                                                                                                                                                                                 |
| routine                           | a piece of executable code with a well-defined <i>entry point</i> and exit point. A routine is similar to a subroutine but may be jumped to or executed on a trap or interrupt rather than called.                                                                                                                                                                                                                                                                           |
| segment                           | a continuous piece of memory defined by a <i>base address</i> and a <i>limit</i> . See also <i>descriptor</i> , <i>32-bit segment</i> , <i>expand-down</i> , and <i>overlaid segments</i> .                                                                                                                                                                                                                                                                                  |
| segmentation<br>hardware          | the parts of the Intel386 family microprocessors that implement <i>protection</i> for accessing <i>segments</i> . See also <i>general protection fault</i> .                                                                                                                                                                                                                                                                                                                 |
| selector                          | a <i>system data structure</i> used in computing an address that identifies a <i>descriptor</i> by specifying a <i>descriptor table</i> and indexing a <i>descriptor</i> within that table. A selector also contains a requested <i>privilege level (RPL)</i> , which is the <i>descriptor privilege level (DPL)</i> of the referring <i>segment</i> . Currently available <i>segments</i> are represented by selectors in the segment registers CS, DS, SS, ES, FS, and GS. |
| slot                              | a particular 8-byte position in a <i>descriptor table</i> .                                                                                                                                                                                                                                                                                                                                                                                                                  |

Italicized words and phrases in a definition refer to other glossary entries.

|                          |                                                                                                                                                                                                                                                                                                                     |
|--------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| system builder, BLD386   | the <b>RLL</b> (DOS) or <b>R&amp;L</b> (VMS) utility that creates a <i>bootloadable system</i> from linkable <i>input modules</i> and <i>system definitions</i> in a <i>build file</i> .                                                                                                                            |
| system data structures   | regions of continuous <i>linear address</i> space with values in defined positions. <i>Descriptors</i> , <i>tables</i> , <i>gates</i> , <i>selectors</i> , and <i>task state segments</i> are the most common system data structures. Sometimes discussion of system data structures includes the system registers. |
| table                    | an array of <i>descriptors</i> and/or <i>gates</i> . Each active table has a system register that points to the table. See also <i>global descriptor table</i> , <i>interrupt descriptor table</i> , and <i>local descriptor table</i> .                                                                            |
| task                     | (1) the code, data, and <i>system data structures</i> which collectively define a sequential thread of execution. (2) one or more of the system data structures associated with a task: <i>task state segments</i> , <i>task</i> or <i>TSS descriptor</i> , or <i>task gate</i> .                                   |
| task state segment (TSS) | a <i>system data structure</i> of a minimum of 68H bytes that at least describes the processor state (such as contents of registers) upon entry to or exit from a <i>task</i> . Other literature refers to this type of data structure as a <i>task control block</i> .                                             |



-> prompt, 1-4, 1-5  
16-bit real mode, 1-5, 2-3, G-1, G-3, G-7  
32-bit protected mode, 1-1, 2-1, 2-3, 2-4, 2-15, 2-22, G-1, G-7  
32-bit segment, G-1, G-3, G-8  
376™ microprocessor, 2-4, 2-9, 2-16, G-1  
386™ microprocessor, 2-3, 2-9, 2-16, G-1  
phantom\_code, 2-2, 2-8, 2-16, 2-17, 2-34  
Base address, 2-2, 2-3, 2-20, 2-21, 2-27  
Descriptor, 2-3  
DPL, 2-2, 2-8, 2-27  
Limit, 2-2, 2-20, 2-21, 2-27  
phantom\_data, 2-2, 2-8, 2-16, 2-17, 2-21, 2-34  
Base address, 2-2, 2-3, 2-20, 2-21, 2-27  
Descriptor, 2-3,  
    see also phantom\_code,  
    phantom\_data, Alias  
descriptor, Gate, Global  
descriptor table, Interrupt  
descriptor table  
DPL, 2-2, 2-8, 2-27  
Limit, 2-2, 2-20, 2-21, 2-27

## A

Absolute address, G-1, G-2, G-7  
Access attributes, G-1, G-2, G-3, G-5  
ACCESS bit, 2-4, G-2  
Alias descriptor, 2-4, 2-23, G-2, G-3  
Application code  
    applic\_code segment, 2-22, 2-34  
    applic\_data, 2-22  
    applic\_func, 2-22  
    appstack segment, 2-22  
    bitcount.c or reverse.c, 2-3  
    code32 segment, 2-3  
    data segment, 2-3

stack segment, 2-3  
main, 2-3  
protect.asm, 2-22, 2-31

ASM386 assembler, 1-3, 2-3, 2-15, 2-33  
debug control, 2-15, 2-33  
Listing files, 2-15  
Object files, 2-15, 2-33  
Warning messages, 1-4, 2-15

## B

Base address, G-2, G-3, G-4, G-5, G-6, G-8  
BASE specification, 2-9  
Binder, 1-3, G-2, G-6  
    Combining segments, 2-3, 2-15, 2-33  
    debug control, 2-15, 2-33  
    Listing files, 2-15  
    noload control, 2-15, 2-33  
    object control, 2-15, 2-33  
    Object files, 2-15, 2-33  
    Resolving symbolic addressing, 2-15, 2-33  
BLD386, 1-1, 1-2, 1-3, 2-1, 2-9, 2-10, 2-16, 2-33, G-3  
    see also Build file, System builder  
BND386, 1-3, 2-15, 2-33  
    see also Binder  
Bootloadable system, 1-1, 2-3, 2-9, 2-10, 2-15, 2-22, G-2, G-3, G-9  
bootstrap control, 2-16, 2-33  
Bootstrap jump, 2-16, G-2, G-8  
    see also Reset vector  
Build file, 2-1, G-3, G-9  
    flat.bld, 1-2, 2-8, 2-9, 2-10, 2-16  
    GATE definition, 2-9  
    ENTRY specification, 2-9

## Build file (continued)

    MEMORY definition, 2-9  
        RANGE specification, 2-10  
        RESERVE specification, 2-10  
    protect.bld, 1-3, 2-27, 2-33  
    RAM, 2-2  
    ROM, 2-2  
    SEGMENT definition, 2-8, 2-20,  
        2-21, 2-27  
    simple.bld, 1-2  
    TABLE definition, 2-8, 2-10, 2-21,  
        2-27  
        LOCATION specification, 2-9  
    TASK definition, 2-9  
Builder, see BLD386, Build file, System  
    builder  
buildfile control, 2-16, 2-33

## C

C-386, 1-2, 1-3, 2-3, 2-15  
    code control, 2-15  
    debug control, 2-15  
    Listing files, 2-15  
    Object files, 2-15  
    regallocate control, 2-15  
c\_startup, 2-4  
code control, 2-15  
Compatibility mode, see 16-bit real  
    mode  
Component, G-3  
copytables, 2-4, 2-22, 2-34

## D

D bit, G-1, G-3  
debug control, 2-15, 2-33  
Descriptor, 1-1, G-1, G-2, G-3, G-4, G-5,  
    G-6, G-8, G-9  
Descriptor privilege level (DPL), 2-2,  
    2-8, 2-27, G-3, G-7, G-8

Descriptor tables, see Global descriptor  
    table (GDT), Interrupt descriptor  
    table (IDT), Local descriptor  
    table (LDT), Tables

Development system, 1-3  
Direction flag, G-4  
Directions, 1-3, 1-4, 1-5

## E

Embedded example, 2-1, 2-3, 2-4, 2-22,  
    2-33  
    bitcount, 2-17  
    bitcount.c, 1-2  
    Build file template, 2-8  
    C startup template, 2-14  
    Creating, 1-4, 2-15, 2-16  
    cstart.asm, 1-2, 2-14  
    Emulating, 1-4, 1-5  
    Executing, 1-5  
    flat.bat, 1-2, 2-15, 2-16  
    flat.bld, 1-2, 2-8  
    flat.com, 1-2, 2-15, 2-16  
    flatinit.asm, 1-2, 2-3, 2-4  
    flatintr.asm, 1-2, 2-12  
    Initialization template, 2-3, 2-4  
    Interrupt stubs template, 2-12  
    Memory map, 2-17  
    reverse.c, 1-2  
    showbitc.inc, 1-2  
    showrevr.inc, 1-2  
    Structure of source files, 2-3

Emulator commands, 2-9

    Error #-26t, 1-5  
    Including, 1-5  
    istep, 1-5  
    showbitc.inc, 1-2  
    showprot.inc, 1-3  
    showrevr.inc, 1-2  
    showsimp.inc, 1-2  
    Entry point, G-4, G-7, G-8  
    ENTRY specification, 2-9  
    Error #-26t, 1-5

Expand-down, G-2, G-4, G-5, G-8  
appstack segment, 2-34  
Base address, 2-21, G-2, G-4  
(ED), 2-21  
Installing descriptor, 2-21, 2-27  
Limit, 2-21, G-4, G-5  
Stack, 2-1, 2-21, 2-27

## F

Far jump, G-1, G-4, G-7  
Fault handler, G-4  
flat control, 2-1, 2-2, 2-3, 2-8, 2-16, 2-33  
Flat model, 1-1, 2-1, 2-3, 2-9, 2-16, 2-20,  
2-21  
default, 2-2, 2-3

## G

Gate, 1-1, 2-2, G-3, G-4, G-5, G-6, G-9  
Descriptors, 2-9, G-4  
Interrupt, 2-9  
Task, 2-9  
Trap, 2-9  
GATE definition, 2-9  
ENTRY specification, 2-9  
gdt\_desc, 2-9, 2-22  
General protection fault, 2-20, G-5, G-7,  
G-8  
Global descriptor table (GDT), 2-8,  
2-17, 2-21, 2-34, G-2, G-5, G-6,  
G-9  
see also Tables  
ACCESS bit in alias descriptor, 2-4  
Alias descriptor, 2-4, 2-23  
Base address, 2-4, 2-9  
Copying from ROM to RAM, 2-4  
Defining, 2-8, 2-9, 2-27  
Installing expand-down stack  
descriptor, 2-27  
Limit, 2-4, 2-9  
Relative base address, 2-23

Global descriptor table register  
(GDTR), G-5

## H-I

Hardware (required), 1-3  
ICE™-376 in-circuit emulator, 2-15  
ICE™-386 in-circuit emulator, 1-2, 1-3,  
2-15  
-> prompt, 1-4  
DOS directory, 1-4  
Executing, 1-5  
Invocation, 1-4  
Real mode, 1-5  
idt\_desc, 2-9, 2-22  
Initialization code, G-2  
code32 segment, 2-3, 2-4, 2-17, 2-22,  
2-34  
copytables, 2-4, 2-22, 2-34  
flatinit.asm, 1-2, 2-3, 2-4  
flatstart, 2-3  
gdt\_desc, 2-9, 2-22  
idt\_desc, 2-9, 2-22  
init\_code segment, 2-3, 2-4, 2-9, 2-17,  
2-22, 2-34  
protinit.asm, 1-3, 2-22, 2-23  
protstart, 2-22  
simpinit.asm, 1-2  
Intel386™ architecture, 1-1  
Instructions  
32-bit, 2-4  
Privileged, 2-15  
Interrupt code  
Dummy interrupt procedure, 2-29  
flatintr.asm, 1-2, 2-3, 2-12  
int\_proc, 2-22  
interrupts, 2-3  
intproc segment, 2-22  
intrupt\_routines segment, 2-3  
protintr.asm, 1-3, 2-22, 2-29  
Public labels of handlers, 2-9  
Stub routines, 2-3, 2-12, G-5

**Interrupt descriptor table (IDT),** 2-17, 2-34, G-2, G-5, G-9  
see also Tables  
Alias descriptor, 2-4, 2-23  
Base address, 2-4, 2-9  
Copying from ROM to RAM, 2-4  
Defining, 2-9, 2-27  
Gate descriptors, 2-9  
Installing interrupt gate, 2-27  
Limit, 2-4, 2-9  
Relative base address, 2-23  
**Interrupt descriptor table register (IDTR),** G-5  
**Interrupt stubs,** G-5  
**Interrupts**  
Defined, 2-12  
Generating, 2-30  
Reserved, 2-12, 2-29  
**istep command,** 1-5

## L

**lgdt instruction,** 2-4, G-2  
**lgdtw instruction,** 2-4  
**Limit,** G-3, G-4, G-5, G-6, G-7, G-8  
**Linear address,** G-5, G-9  
**Linked input segments,** 2-1  
**Linker,** see binder  
**Listing files**  
bitcount.lst, 2-15  
bitcount.mp1, 2-15  
bitcount.mp2, 2-16, 2-17  
cstart.lst, 2-15  
flatinit.lst, 2-15  
flatintr.lst, 2-15  
protect.mp2, 2-34  
reverse.lst, 2-15  
reverse.mp1, 2-15  
reverse.mp2, 2-16  
**Local descriptor table (LDT),** 2-10, G-6, G-9  
see also Tables  
**Contents in builder listing,** 2-10

**Creating,** 2-10  
**Eliminating from bootloadable system,** 2-10  
**LDT1,** 2-10  
**Local descriptor table register (LDTR),** G-6  
**LOCATION specification,** 2-9

## M

**Machine status word,** G-1, G-6, G-7  
**Map files**  
bitcount.mp1, 2-15  
bitcount.mp2, 2-16, 2-17  
protect.mp2, 2-34  
reverse.mp1, 2-15  
reverse.mp2, 2-16

**Memory addresses wrapping,** 2-21, 2-23  
**Memory configuration,** 2-1, 2-10, 2-17, 2-33, 2-34, G-3

RAM, 2-4  
ROM, 2-4

**MEMORY definition,** 2-9  
**RANGE specification,** 2-10  
**RESERVE specification,** 2-10

**Memory maps**  
Default flat memory model, 2-2  
Embedded example, 2-17  
Minimally protected flat model, 2-20  
Protected example, 2-34  
Protected flat model with expand-down stack, 2-21  
**mod376 control,** 2-16, 2-33  
**Module,** G-2, G-6, G-9

## N-O

**Near jump,** G-2, G-6  
**noload control,** 2-15, 2-33  
**object control,** 2-15, 2-33  
**Object modules**  
asmstart.obj, 2-33  
bitcount.bnd, 2-15, 2-16

## Object modules (continued)

bitcount.obj, 2-15  
cstart.obj, 2-15  
flatinit.obj, 2-15  
flatintr.obj, 2-15  
intrpt.obj, 2-16  
protect.bnd, 2-33  
protect.obj, 2-33  
protinit.obj, 2-33  
protintr.obj, 2-33  
reverse.bnd, 2-15, 2-16  
reverse.obj, 2-15

Offset, G-2, G-4, G-5, G-6, G-7, G-8

Operand prefix, 2-4, G-1, G-6

Overlaid segments, G-6, G-8

## P

PE bit, see Protection-enable (PE) bit

Physical address, G-2, G-5, G-6, G-7, G-8

Prefetch queue, G-7

Privilege level, G-3, G-4, G-5, G-7, G-8  
see also Descriptor privilege level (DPL)

Privileged instructions, G-3, G-7

Program Development Templates disk (DOS), 1-4

Protected example, 2-1, 2-22

Application template, 2-31

ASM386 startup template, 2-30

asmstart.asm, 1-3, 2-30

Build file template, 2-27

Creating, 1-4, 2-33

Differences from embedded example, 2-22

Dummy interrupt, 2-22

Dummy interrupt template, 2-29

Emulating, 1-4, 1-5

Executing, 1-5

Expand-down stack, 2-22

Initialization template, 2-22, 2-23

Dependency on phantom segments' base, 2-23

Memory map, 2-33, 2-34

protect, 2-34

protect.asm, 1-3, 2-31

protect.bat, 1-3, 2-33

protect.bld, 1-3, 2-27, 2-33

protect.com, 1-3, 2-33

protinit.asm, 1-3, 2-22, 2-23

protintr.asm, 1-3, 2-29

showprot.inc, 1-3

Structure of source files, 2-22

Protected flat model, 2-20, 2-21, 2-27

Minimum definition, 2-20

Protected flat model with expand-down stack, 2-21

Protected mode (32-bit), 1-1, 2-1, 2-3, 2-4, 2-15, 2-22

Protection, G-3, G-4, G-5, G-7, G-8

Protection levels, 2-1, G-7

see also Descriptor privilege level (DPL)

Protection-enable (PE) bit, G-1, G-6, G-7

## R

RANGE specification, 2-10

Real mode (16-bit), 1-5, 2-3

regallocate control, 2-15

Relative base, G-2, G-8

Relocating, G-2, G-8

RESERVE specification, 2-10

Reset vector, 2-17, 2-34, G-2, G-8

see also Bootstrap jump

RLL, 1-3

ROM-based systems, 2-4

Returning a READY on a write, 2-4

Routine, G-5, G-8

# S

Segment, 1-1, G-2, G-3, G-4, G-5, G-6, G-7, G-8  
32-bit, 2-4, G-1, G-3, G-8  
Access attributes, 2-2, 2-10, G-1, G-2, G-3, G-5  
Executable . 2, 2-10, G-1  
Linking input, 2-1  
Overlaid, 2-2, 2-8, G-6, G-8  
Read-only, 2-2, 2-10, G-1  
Read-write, 2-2, 2-10, G-1  
Writable, G-2  
**SEGMENT** definition, 2-8, 2-20, 2-21, 2-27  
Segmentation hardware, 2-20, G-3, G-7, G-8  
Selectors, 1-5, G-1, G-2, G-4, G-6, G-7, G-8, G-9  
  
Simple example  
    Creating, 1-4  
    cstart.asm, 1-2  
    Emulating, 1-4, 1-5  
    Executing, 1-5  
    showsimp.inc, 1-2  
    simpinit.asm, 1-2  
    simple.bat, 1-2  
    simple.bld, 1-2  
    simple.c, 1-2  
    simple.com, 1-2  
Slot, G-5, G-8  
Software (required), 1-3  
Source code  
    asmstart.asm, 1-3, 2-30  
    bitcount.c, 1-2  
    bitcount.c or reverse.c, 2-3  
    cstart.asm, 1-2, 2-14  
    File structure for embedded example, 2-3  
    File structure for protected example, 2-22  
    flat.bat, 1-2

flat.bld, 1-2, 2-10  
flat.com, 1-2  
flatinit.asm, 1-2, 2-4  
flatintr.asm, 1-2, 2-12  
protect.asm, 1-3, 2-31  
protect.bld, 1-3, 2-27  
protinit.asm, 1-3, 2-23  
protintr.asm, 1-3, 2-29  
reverse.c, 1-2  
simpinit.asm, 1-2  
simple.bld, 1-2  
simple.c, 1-2  
Stack, 2-2, 2-10, 2-17, 2-20, 2-21  
    Defining, 2-14, 2-30  
    Overflow protection, 2-21  
    Separate expand-down, 2-21  
Stack pointer  
    Initializing, 2-14, 2-30  
start, 2-16, 2-33  
Startup code, 2-4  
    asmstart, 2-22  
    asmstart.asm, 1-3, 2-22, 2-30  
    c\_startup, 2-4  
    code32 segment, 2-3  
    cstart, 2-3  
    cstart.asm, 1-2, 2-3, 2-14  
    data segment, 2-3  
    stack segment, 2-3  
    syscode segment, 2-22, 2-34  
    sysdata segment, 2-22  
    systack segment, 2-22  
**SYS&ROOT:[SYSHLP.EASE]**  
    directory (VMS), 1-4  
System builder, 1-1, 1-3, 2-1, 2-2, 2-4, 2-10, 2-21, 2-22, G-2, G-3, G-6, G-9  
    see also Build file  
Allocating space, 2-2  
bootstrap control, 2-16, 2-33  
buildfile control, 2-16, 2-33  
Combining segments, 2-2  
Final system files, 2-16  
flat control, 2-1, 2-2, 2-8, 2-16, 2-33

**System builder (continued)**  
Listing files, 2-16, 2-17, 2-34  
mod376 control, 2-16, 2-33  
Warning messages, 1-4, 2-16  
**System data structures**, 1-1, 2-1, 2-9, 2-17, 2-33, 2-34, G-3, G-8, G-9  
see also *Alias descriptors*, *Descriptor*, *Gate*, *Tables*, *Task state segments*, *Selectors*

**System reset**, 2-1

**Systems (example)**  
bitcount, 1-2, 1-4, 1-5, 2-16  
Creating, 1-4  
Different kinds, 1-1  
Embedded, 1-1  
Emulating, 1-4, 1-5  
Executing, 1-5  
protect, 1-3, 1-4, 1-5, 2-33  
Protected, 1-1  
RAM, 1-1  
reverse, 1-2, 1-4, 1-5, 2-16  
ROM, 1-1  
Simple, 1-1, 1-2, 1-4, 1-5  
Type of example, 1-2

## T

**TABLE definition**, 2-8, 2-9, 2-10, 2-21, 2-27  
**Tables**, 2-2, 2-4, 2-10, G-2, G-3, G-8, G-9  
see also *Global descriptor table (GDT)*, *Interrupt descriptor table (IDT)*, *Local descriptor table (LDT)*  
Address calculation, 2-4, 2-22  
Copying from ROM to RAM, 2-4, 2-22  
Location in memory, 2-4, 2-9  
Relocating without re-assembling, 2-9  
**Task**, 2-9, G-4, G-5, G-6, G-9  
**TASK definition**, 2-9

**Task state segment (TSS)**, 2-2, 2-10, G-2, G-3, G-6, G-9  
**DOS location**, 1-4  
**main\_task**, 2-17, 2-34  
**Source code**, 1-2, 1-3  
**VMS location**, 1-4  
**Templates**, 1-1, 2-1, 2-15

## U

**USE32 use-attribute**, G-1  
see also *D bit*, *descriptor*

## W

**Warning messages**, 1-4, 2-15, 2-16





## International Sales Offices

### BELGIUM

Intel Corporation SA  
Rue des Cottages 65  
B-1180 Brussels

### DENMARK

Intel Denmark A/S  
Glentevej 61-3rd Floor  
dk-2400 Copenhagen

### ENGLAND

Intel Corporation (U.K.) LTD.  
Piper's Way  
Swindon, Wiltshire SN3 1RJ

### FINLAND

Intel Finland OY  
Ruosilante 2  
00390 Helsinki

### FRANCE

Intel Paris  
1 Rue Edison-BP 303  
78054 St.-Quentin-en-Yvelines Cedex

### ISRAEL

Intel Semiconductors LTD.  
Atidim Industrial Park  
Neve Sharet  
P.O. Box 43202  
Tel-Aviv 61430

### ITALY

Intel Corporation S.P.A.  
Milandfiori, Palazzo E/4  
20090 Assago (Milano)

### JAPAN

Intel Japan K.K.  
5-6 Tokodai, Tsukuba-shi  
Ibaraki, 300-26

### NETHERLANDS

Intel Semiconductor (Nederland B.V.)  
Alexanderpoort Building  
Marten Meesweg 93  
3068 Rotterdam

### NORWAY

Intel Norway A/S  
P.O. Box 92  
Hvamveien 4  
N-2013, Skjetten

### SPAIN

Intel Iberia  
Calle Zurbaran 28-IZQDA  
28010 Madrid

### SWEDEN

Intel Sweden A.B.  
Dalvaegen 24  
S-171 36 Solna

### SWITZERLAND

Intel Semiconductor A.G.  
Talackerstrasse 17  
8125 Glattbrugg  
CH-8065 Zurich

### WEST GERMANY

Intel Semiconductor GmbH  
Seidlestrasse 27  
D-8000 Muenchen 2





## READER RESPONSE CARD

Program Development

Templates

481894-001

### We'd Like Your Opinion

Please use this form to help us evaluate the effectiveness of this manual and improve the quality of future versions.

To order publications, contact the Intel Literature Department (see page ii of this manual).

Fill in the squares below with a rating of 1 through 10:

| POOR | AVERAGE | EXCELLENT |   |   |   |   |   |   |    |
|------|---------|-----------|---|---|---|---|---|---|----|
| 1    | 2       | 3         | 4 | 5 | 6 | 7 | 8 | 9 | 10 |

|                          |                                       |
|--------------------------|---------------------------------------|
| <input type="checkbox"/> | Readability                           |
| <input type="checkbox"/> | Technical depth                       |
| <input type="checkbox"/> | Technical accuracy                    |
| <input type="checkbox"/> | Usefulness of material for your needs |
| <input type="checkbox"/> | Comprehensibility of material         |
| <input type="checkbox"/> | OVERALL QUALITY OF THIS MANUAL        |

If you gave a 4 or less (in any category), please explain here:

---

---

---

What suggestions would you have for improving this manual:

---

---

---

If you would like us to call you for more specific suggestions about this book, please additionally fill in your phone number below.

Name \_\_\_\_\_

Phone Number (\_\_\_\_\_) \_\_\_\_\_

Address \_\_\_\_\_

---

---

Thanks for taking the time to fill out this form.



NO POSTAGE  
NECESSARY  
IF MAILED  
IN THE  
UNITED STATES

**BUSINESS REPLY MAIL**

FIRST CLASS PERMIT NO. 79 HILLSBORO, OR

POSTAGE WILL BE PAID BY ADDRESSEE



**INTEL CORPORATION**  
**DTO TECHNICAL PUBLICATIONS HF2-38**  
**5200 NE ELAM YOUNG PARKWAY**  
**HILLSBORO OR 97124-9978**



Please fold here and close the card with tape. Do not staple.

**WE'D LIKE YOUR COMMENTS . . .**

This document is one of a series describing Intel products. Your comments on the other side of this form will help us produce better manuals. Each reply will be reviewed. All comments and suggestions become the property of Intel Corporation.

If you are in the United States and are sending only this card, postage is prepaid.

If you are sending additional material or if you are outside the United States, please insert this card and any enclosures in an envelope. Send the envelope to the above address, adding "United States of America" if you are outside the United States.

Thanks for your comments.



---

**INTEL CORPORATION**  
5200 N.E. Elam Young Pkwy.  
Hillsboro, Oregon 97123

